[英]ArrayIndexOutOfBoundExceptions on certain inputs when sorting elements of an array?
我的任务是编写一个重新排列数组的函数,以使奇数出现在数组的开头(从最大到最小),偶数从最小到最大出现在结尾。 除了标准输入和输出流,我们不允许使用任何其他库。
当数字为时,输出有效:
{-15, 450, 6, -9, 54}
但是,如果我将元素更改为:
{-55, 45, 6, 11, 54}
存在异常错误。 这是我的代码:
public class ary1 {
public static void sort(int A[], int n) {
int tmp;
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
if (A[0] % 2 == 0) //even
{
if (A[i] < A[j]) {
tmp = A[i];
A[i] = A[j];
A[j] = tmp;
}
} else {
if (A[i] > A[j]) {
tmp = A[i];
A[i] = A[j];
A[j] = tmp;
}
}
}
}
}
public static void showAray(int A[], int n) {
for (int i = 0; i < n; i++) {
System.out.println(A[i]);
}
}
public static void main(String args[]) {
int array1[] = {-55, 45, 6, 11, 54};
int odd = 0;
int even = 0;
for (int i = 0; i < array1.length; i++) {
if (array1[i] % 2 == 0) {
even++;
} else {
odd++;
}
}
int[] array2 = new int[even];
int[] array3 = new int[odd];
for (int i = 0, j = 0, k = 0; i < array1.length; i++) {
if (array1[i] % 2 == 0) {
array2[j++] = array1[i];
} else {
array3[k++] = array1[i];
}
}
System.out.println("Original array:\n");
showAray(array1, array1.length);
sort(array2, even);
sort(array3, odd);
for (int i = 1; i < array1.length; i++) {
if (i < odd) {
array1[i] = array3[i];
} else {
array1[i] = array2[(i + 1) - even];
}
}
System.out.println("\nAfter sorting:\n");
showAray(array1, array1.length);
}
}
我知道这里存在逻辑错误,但我无法弄清楚到底是什么。 有什么方法可以更改逻辑以使用所有整数吗? 谢谢。
array1[i] = array2[(i + 1) - even];
编辑-这是stacktrace。
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 2
at ary.main(arytest.java:67)
Java Result: 1
改变这个
array1[i] = array2[(i + 1) - even];
至
array1[i] = array2[i - odd];
我想这就是你想要的
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.