区分冒泡与选择排序

我已经被选择冒泡整蒙了,比如说这次懂了,下次又不懂了,没办法,就要再看。我觉得这个原因是自己理解不够透彻,所以多看看,总有一天这个东西不会再弄混淆。

这个是看的资料,不过博主的代码有点问题,我做了一点修改


冒泡算法:假设数组长度为lenght,冒泡算法的外循环为lenght-1,内循环则为相邻的两个数之间不断比较,直到数组末尾结束。其实现如下。

for(int i=1;ifor(int j=0;jif(arry[j]>arry[j+1]){
temp=arry[j];
arry[j]=arry[j+1];
arry[j+1]=temp;
}
}
}


选择排序:假设数组长度为lenght,选择排序的外循环也是lenght-1,内循环则为使用第一个数与其他的数比较,得出一个最小的数,将最小数与数组的第一个元素交换;第二次外循环,则用数组的第二个数与第三到底lenght个数比较,找到其中的最小值,并将此最小值与数组的第二个数交换,一直下去,直到数组末尾。

程序如下所示:


for(int i=0;ifor(int j=i+1;jif(arry[i]>arry[j]){
temp=arry[i];
arry[i]=arry[j];
arry[j]=temp;

}
}
}

你可能感兴趣的:(区分冒泡与选择排序)