在这个程序中,我使用mergeSort 对奥运奖牌进行排序。
我的代码似乎有点不对劲,因为有时它会给我一个 java.lang.ArrayIndexOutOfBoundsException ,有时它不会。
对于一些背景说明:
我有一种方法可以随机生成奥运国家和他们在记分牌中获得的奖牌。以以下形式返回结果的 String[] 数组:
可以 1 1 1
美国 1 1 2
英国 0 0 1
中国 0 0 2
然而,记分牌需要按金、银、铜牌的递减顺序排列。所以它必须是这样的:
美国 1 1 2
可以 1 1 1
中国 0 0 2
英国 0 0 1
使用冒泡排序和快速排序对棋盘进行排序可以正常工作,但归并排序不行。有时它会很好,但更多时候它会给我 ArrayIndexOutOfBoundsException。
public static void main(String[] args) {
Olympic_Results score = new Olympic_Results();
//print a return value of an array
String[] countries = score.OlympicResult(7); //input how many game results
mergeSort(countries, 0, countries.length - 1);
for (String value:countries)
System.out.println(value);
}
public static void mergeSort(String array[], int lo, int n) {
int low = lo;
int high = n;
if (low >= high) {
return;
}
int middle = (low + high) / 2;
mergeSort(array, low, middle);
mergeSort(array, middle + 1, high);
int end_low = middle;
int start_high = middle + 1;
while ((lo <= end_low) && (start_high <= high)) {
if ((array[low].substring(4,8)).compareTo(array[high].substring(4,8)) > 0) {
low++;
}
else {
String Temp = array[start_high];
for (int k = start_high - 1; k >= low; k--) {
array[k + 1] = array[k];
}
array[low] = Temp;
low++;
end_low++;
start_high++;
}
}
}
知道为什么这段代码不能正常工作吗?谢谢!