我今天在课堂上有一个带有冒泡排序的教程,我有一个错误,我不知道如何修复。
线程“main”中的异常java.lang.ArrayIndexOutOfBoundsException:8 在BubbleSorter.main(BubbleSorter.java:24)
没有评估,但我想通过它继续。 谢谢。以下是我的整个代码。
public class BubbleSorter {
public static void main(String[] args)
{
int i;
int array[] = { 12, 9, 4, 99, 120, 1, 3, 10 };
System.out.println("Array Values before the sort:\n");
for (i = 0; i < array.length; i++)
System.out.print(array[i] + " ");
System.out.println();
System.out.println();
bubble_srt(array, array.length);
System.out.print("Array Values after the sort:\n");
for (i = 0; i < array.length; i++)
;
System.out.print(array[i] + " ");
System.out.println();
System.out.println("PAUSE");
}
private static void bubble_srt(int[] array, int length) {
int i, j, t = 0;
for (i = 0; i < length; i++) {
for (j = 1; j < (length - 1); j++) {
if (array[j - 1] > array[j]) {
t = array[j - 1];
array[j - 1] = array[j];
array[j] = t;
}
}
}
}
}
答案 0 :(得分:7)
你有一个小错误:
此:
for (i = 0; i<array.length; i++);
System.out.print(array[i] + " ");
应该是:
// v - Semicolon removed
for (i = 0; i<array.length; i++)
System.out.print(array[i] + " ");
答案 1 :(得分:2)
同时更改
for (j = 1; j < (length - 1); j++) {
到
for (j = 1; j < length; j++) {
你遗漏了数组的最后一个元素!
输出
Array Values before the sort:
12 9 4 99 120 1 3 10
Array Values after the sort:
1 3 4 9 10 12 99 120
PAUSE
答案 2 :(得分:0)
您需要更改2行
for (i = 0; i < array.length; i++)
;
System.out.print(array[i] + " ");
到
for (i = 0; i < array.length; i++)
System.out.print(array[i] + " ");
和
for (j = 1; j < (length - 1); j++) {
到
for (j = 1; j < (length); j++) {
答案 3 :(得分:0)
在第18行,你需要摆脱;或放在括号{