我在查找数组中最小值的索引时引用或实例化错误吗?
Am I referencing or instancing wrong for finding the index of the smallest value in an array?
我的数组是:
int a = new int[] {20,20,30,40,6,70,80}
我寻找最小值的代码是正确的,但是当我尝试输入
idx=i
或
idx= i+1
和returnidx
,我的输出是0.
int minval=0;
int idx=0;
if(a==null || a.length==0) {
return null;
}
else if(a.length!=0) {
for(int i=0; i<a.length-1; i++) {
if(a[i]<a[i+1]) {
a[i+1]=a[i];
minval=a[i];
}
else
minval= a[i+1];
}
return minval;
}
return null;
}
您应该将每个元素与当前最小值而不是相邻值进行比较。
int minIdx = 0;
for(int i = 1; i < a.length; i++) {
if(a[i] < a[minIdx]) minIdx = i;
}
return minIdx; //minIdx is index of smallest value; a[minIdx] is the smallest value
我的数组是:
int a = new int[] {20,20,30,40,6,70,80}
我寻找最小值的代码是正确的,但是当我尝试输入
idx=i
或
idx= i+1
和returnidx
,我的输出是0.
int minval=0;
int idx=0;
if(a==null || a.length==0) {
return null;
}
else if(a.length!=0) {
for(int i=0; i<a.length-1; i++) {
if(a[i]<a[i+1]) {
a[i+1]=a[i];
minval=a[i];
}
else
minval= a[i+1];
}
return minval;
}
return null;
}
您应该将每个元素与当前最小值而不是相邻值进行比较。
int minIdx = 0;
for(int i = 1; i < a.length; i++) {
if(a[i] < a[minIdx]) minIdx = i;
}
return minIdx; //minIdx is index of smallest value; a[minIdx] is the smallest value