會不會存在if(arr[j]<arr[j+1])如果存在怎么解釋
會不會存在if(arr[j]<arr[j+1])如果存在怎么解釋
j=0時
數(shù)值交換后arr[0]=1.77,arr[1]=1.78
j=1時
沒交換時arr[2]=1.82 ? ?arr[1]<arr[1+1]怎么解釋啊
會不會存在if(arr[j]<arr[j+1])如果存在怎么解釋
j=0時
數(shù)值交換后arr[0]=1.77,arr[1]=1.78
j=1時
沒交換時arr[2]=1.82 ? ?arr[1]<arr[1+1]怎么解釋啊
2016-05-25
舉報
2016-05-27
if(arr[j]<arr[j+1])
{
????????temp=arr[j];//前面聲明temp
????????arr[j]=arr[j+1];
????????arr[j+1]=temp;
}
如果滿足arr[j]<arr[j+1],那么arr[j]和arr[j+1]就會交換值,如果不滿足這個條件的話就不會交換例如arr[j]>arr[j+1],那么編譯器就不會去交換arr[j]和arr[j+1]的值.
好比開始是arr[0]=3,arr[1]=4,arr[2]=2.
當J=0時arr[0]和arr[1]值交換,arr[0]=4,arr[1]=3;
當J=1時arr[1]>arr[2],arr[1]和arr[2]的值不會交換,既arr[1]還是=3,? arr[2]還是=2.
2016-06-15
這段主要是將相鄰兩個數(shù)進行比較,
如果前面的數(shù) > 后面的數(shù)? 就將前后數(shù)對調(diào)
如果前面的數(shù) < 后面的數(shù) 就不需要做什么
總之,兩相鄰數(shù)比較后的結(jié)果是將較大的數(shù)放到后面,這個較大的數(shù)再與其后面相鄰的數(shù)比較,保證每次比較后,較大的數(shù)都在后者的位置,這樣一串數(shù)字中,最大的數(shù)就跑到了最后面,這就是帽泡排序。,