IndexOfMaxInRange的麻烦

IndexOfMaxInRange的麻烦

我发布帖子只是因为我碰到了我正在编写的代码。

代码的目标是使用selectionSort方法中的swap和IndexOMaxInRange方法从最大到最小对数组进行排序。我知道我的代码可能很草率,但是我确实对这门程序感到困惑。

我的问题是:

为什么我会不断收到“解析时到达末尾”错误,这很明显,但是我不热衷于使用return语句,因此在尝试调试时可能会有所帮助,但我却迷失了。

运行代码时返回的错误是:

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 3
at indexofmaxinrange.IndexOfMaxInRange.selectionSort(IndexOfMaxInRange.java:27)
at indexofmaxinrange.IndexOfMaxInRange.main(IndexOfMaxInRange.java:36)
Java Result: 1

code:


package indexofmaxinrange;
import java.util.Arrays;
/**
* @author zrcenivi
*/

public class IndexOfMaxInRange {
public static int indexOfMaxInRange (int[]a){
Arrays.sort(a);
int gindex = a.length - 1;
return gindex;
}
public static int[] swapElement(int[]a2, int j, int i) {
int temp = i;
a2[i] = a2[j];
a2[j] = temp;
return a2;
}
public static int[] selectionSort(int[]a){
Arrays.sort(a);
int min=0; int temp;
for (int i=0;i<=a.length - 1;i++){
min = i;
}
for (int j = a.length; j >=0; j--){
if (a[min]<a[j]){
a = swapElement(a,a[min],a[j]);
}
}
return a;
}
public static void main(String[] args) {
int[] A = {1,3,2};
System.out.println(selectionSort(A));
}

最佳答案

尝试这个

for (int j = a.length - 1; j >=0; j--) {
}


代替

for (int j = a.length; j >=0; j--){
}


此外,这将打印您期望的

public static void main(String[] args) {
  int[] A = { 1, 3, 2 };
  System.out.println(Arrays.toString(selectionSort(A)));
}

关于java - IndexOfMaxInRange的麻烦,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19945674/

10-08 21:22