java語言基礎數組選擇排序從小到大-作者:逝秋

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章