class Text1
{
//選擇排序:從小到大
public static void main(String[] args)
{
int[]arr=new int[]{12,9,56,45,10};
for (int c=0;c<arr.length;c++ )//控制從角標o到數組.length-1的比較次數
{
for (int b=c+1;b<arr.length;b++ )//從上for中得到角標(c)與該角標與之比較的相應角標(c+1循環)的大小比較
{
if(arr[c]>arr[b])
{
arr[c]=arr[b];//這裏思路錯誤,最終得到每次比較的最小值而不是整體數組的最小值
}
}
System.out.print(arr[c]);//第一次跳出內循環:arr{9,9,56,45,10}第二次跳出:arr{9,9,56,45,10}第三次跳出{9,9,10,45,10}
}
}
}
class Text2
{
public static void main(String[] args)
{
int[]arr=new int[]{12,9,56,45,10};
for (int c=0;c<arr.length ;c++ )
{
for (int b=c+1;b<arr.length;b++ )
{
if(arr[c]>arr[b])
{
int tep=arr[c];//實現兩個變量的值互換,由此可以排列出數組從小到大
arr[c]=arr[b];
arr[b]=tep;
}
}
System.out.print(arr[c]+" ");//第一次跳出內循環:arr{9,12,56,45,10}第二次跳出:arr{9,10,56,45,12}
}
}
}
輸出結果:
通過比較以後得出:如果數組的值在for循環中被重新賦值
int []arr=new int []{12,9,56,45,10};
for(int a=0;a<5;a++)
{
arr[a]=a+2;
}//當for循環結束時arr[]={14,11,58,47,12}
轉載請註明出處,謝謝!作者:逝秋http://blog.csdn.net/vvqiu