import java.io.File;
import java.io.FileNotFoundException;
import java.util.Scanner;
public class InversionCounter {
public static void main(String[] args) {
Scanner scanner = null;
try {
scanner = new Scanner(new File("src/IntegerArray.txt"));
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
int [] nums = new int [100000];
int i = 0;
while(scanner.hasNextInt()){
nums[i++] = scanner.nextInt();
}
System.out.println(countInversions(nums));
}
public static int countInversions(int[] nums) {
int count = 0;
for (int i=0;i<nums.length-1;i++) {
for (int j=i+1;j<nums.length;j++) {
if (nums[i]>nums[j]) {
count++;
}
else {continue;}
}
}
return count;
}
}
上面的代码从文件中读取100,000个整数,并计算此整数数组的反转。输出可能是一个非常大的数字,如1198233847,肯定是积极的。但是,它会输出负值,如-1887062008。程序逻辑可能是正确的,因为我尝试了其他算法用于相同的目的,并得到与输出相同的负数。我怀疑结果是一个太大的正数,因此Java将其转换为负数。
答案 0 :(得分:3)
int
的最大值是2,147,483,647 - 你看到的是溢出。如果你希望它count
,你应该long
{{1}}。
来源:http://docs.oracle.com/javase/tutorial/java/nutsandbolts/datatypes.html
答案 1 :(得分:2)
这里最糟糕的情况是4,999,950,000次反转,这大于int的最大值(2,147,483,647)。您应该使用long来存储号码。