这里我希望Stringbuilder附加每个计算的结果。 但它没有以正确的格式出现。
在代码中我试图找到两个数字的所有comman因子并得到第k个值。但我的结果并没有达到预期的格式。
Expected Correct Output
4
1
No candy today
我得到的是: -
4
4
1
4
1
No candy today
我需要使用StringBuilder来快速处理输出。每次我只需要调用一次,而不是调用System.out。
import java.util.*;
class TestClass {
public static void main(String args[] ) throws Exception {
StringBuilder sb = new StringBuilder();
Scanner scan = new Scanner(System.in);
int D = scan.nextInt();
int x = 0, y = 0, k = 0;
List<Integer> commonDivisor = new ArrayList<Integer>();
while(D-->0){
commonDivisor.clear();
x = scan.nextInt();
y = scan.nextInt();
k = scan.nextInt();
k = k - 1;
commonDivisor = getCommonDivisor(x, y);
Collections.reverse(commonDivisor);
if(k >= (commonDivisor.size())){
sb.append("\nNo candy today");
}else if(k <= (commonDivisor.size() - 1)){
sb.append(commonDivisor.get(k) + "\n");
}
System.out.println(sb);
}
}
public static List<Integer> getCommonDivisor(int num1, int num2) {
List<Integer> list = new ArrayList<Integer>();
int min = minimum(num1, num2);
for(int i = 1; i <= min / 2; i++) {
if (num1 % i == 0 && num2 % i == 0) {
list.add(i);
}
}
if (num1 % min == 0 && num2 % min == 0) {
list.add(min);
}
return list;
}
public static int minimum(int num1, int num2) {
return num1 <= num2 ? num1 : num2;
}
}
答案 0 :(得分:2)
您在每次循环迭代中打印字符串构建器,因此您打印所有步骤。由于您希望避免在循环内打印而是构建一个在最后打印的字符串,您应该将print语句移到循环之外:
while(D-->0){
commonDivisor.clear();
x = scan.nextInt();
y = scan.nextInt();
k = scan.nextInt();
k = k - 1;
commonDivisor = getCommonDivisor(x, y);
Collections.reverse(commonDivisor);
if (k >= commonDivisor.size()) {
sb.append("\nNo candy today");
} else if (k <= (commonDivisor.size() - 1)){
sb.append(commonDivisor.get(k) + "\n");
}
}
System.out.println(sb);
答案 1 :(得分:1)
您需要在完成测试用例后清除stringBuilder,或者在处理完所有测试用例后进行打印。您已经掌握并在每个测试用例后在while循环中打印它。因此有两种方法可以解决这个问题:
}//while loop ends
System.out.println(sb);//this is what i would prefer
或者
while(D-->0){
sb = new StringBuilder();
...
答案 2 :(得分:1)
在循环中将此行写在外面。休息似乎没问题。
System.out.println(sb);