(这是我的家庭作业。所以我无法对任务进行任何更改,例如更改输入规则。)
我需要计算
a^m mod n
并打印出结果。 (我已经知道如何编码计算。)
但问题是说有多行输入:
IN:
12 5 47
2 4 89
29 5 54
并且需要在阅读所有输入行后一起打印所有结果。 (您无法在一行输入后立即打印结果。)
OUT:
14
16
5
到目前为止我尝试过的代码:
import java.util.Scanner;
public class mod {
public static void main(String[] args){
Scanner input = new Scanner(System.in);
int count = 0;
while (input.hasNextLine()){
count++;
}
int[] array = new int[count];
for (int i = 0; i < count; i ++){
int a = input.nextInt();
int m = input.nextInt();
int n = input.nextInt();
int result = (int)((Math.pow(a, m)) % n);
array[i] = result;
}
for (int x : array){
System.out.println(x);
}
}
}
我尝试计算输入行并构建一个大小的数组来存储结果。
但似乎我的代码无法检测到输入结束并继续循环。
答案 0 :(得分:1)
您可以使用List<String>
将用户的输入存储在初始循环中,我建议在空String
上终止循环,并且只添加与由空白字符分隔的三个数字匹配的行。另外,我会在第二个循环中打印结果。那么您不需要结果array
。我也更喜欢格式化的io(即System.out.printf
)。像,
Scanner input = new Scanner(System.in);
List<String> lines = new ArrayList<>();
while (input.hasNextLine()) {
String line = input.nextLine();
if (line.isEmpty()) {
break;
} else if (line.matches("\\d+\\s+\\d+\\s+\\d+")) {
lines.add(line);
}
}
int count = lines.size();
for (int i = 0; i < count; i++) {
String[] tokens = lines.get(i).split("\\s+");
int a = Integer.parseInt(tokens[0]), m = Integer.parseInt(tokens[1]),
n = Integer.parseInt(tokens[2]);
int result = (int) ((Math.pow(a, m)) % n);
System.out.printf("(%d ^ %d) %% %d = %d%n", a, m, n, result);
}
我使用您提供的输入进行了测试,
12 5 47
2 4 89
29 5 54
(12 ^ 5) % 47 = 14
(2 ^ 4) % 89 = 16
(29 ^ 5) % 54 = 5