为了账号安全,请及时绑定邮箱和手机立即绑定

仅使用整数计算 2^n%k

仅使用整数计算 2^n%k

慕姐4208626 2024-01-25 10:45:01
我需要编写一个代码来获取 2 个变量 (n,k) 并打印 (2^n)%k 的答案。我只能使用整数,不能使用方法,不能使用数组,不能使用数学。等等。到目前为止我有这个:int n = myScanner.nextInt();      int k = myScanner.nextInt();       int num = 1;    int modulo = 1;    for (int i = 0; i < n; i++) {                num = num * 2;              modulo *= 2%k;    }    modulo = modulo%k;    System.out.println(modulo);问题是 int 本身的范围,不超过 2^31...但我仍然需要让它以某种方式工作,任何帮助将非常感激!
查看完整描述

2 回答

?
慕盖茨4494581

TA贡献1850条经验 获得超11个赞

您正在处理模幂。int一种可能的解决方案是通过利用以下优势来避免大数相乘,这会溢出:

给定两个整数 a 和 b,以下两个方程是等价的:

c mod m = (a ⋅ b) mod m

c mod m = [(a mod m) ⋅ (b mod m)] mod m

在 Java 中,基于本节中解释的算法的简单解决方案:

int mod(int base, int exponent, int modulus) {

  if (modulus == 1) return 0;

  int c = 1;

  for (int i = 0; i < exponent; i++) {

    c = (c * base) % modulus;

  }

  return c;

}


查看完整回答
反对 回复 2024-01-25
?
ABOUTYOU

TA贡献1812条经验 获得超5个赞

如果您的问题是它无法存储超过 2^31,那是因为您需要使用长数据类型来存储该值。long 可以存储最大值 2^63(有符号)。



查看完整回答
反对 回复 2024-01-25
  • 2 回答
  • 0 关注
  • 101 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信