常用排序算法整理讲义.docx

1、冒泡排序 (Bubble Sort)对于一个已经排序好的序列,它的任意两个相邻元素,都应该满足a[i-1] = a[i]的关系。冒泡排序相当暴力的实现了这一目标:不断扫描相邻元素,看它们是否违章。一旦违章,立即纠正。在冒泡排序时,计算机从右向左遍历数组,比较相邻的两个元素。如果两个元素的顺序是错的,那么sorry,请两位互换。如果两个元素的顺序是正确的,则不做交换。经过一次遍历,我们可以保证最小的元素(泡泡)处于最左边的位置。然而,经过这么一趟,冒泡排序不能保证所有的元素已经按照次序排列好。我们需要再次从右向左遍历数组元素,进行冒泡排序。这一次遍历,我们不用考虑最左端的元素,因为该元素已经是最小的。遍历结束后,继续重复扫描…… 总共可能进行n-1次的遍历。如果某次遍历过程中,没有发生交换,bingo,这个数组已经排序好,可以中止排序。如果起始时,最大的元素位于最左边,那么冒泡算法必须经过n-1次遍历才能将数组排列好,而不能提前完成排序。/*By Vamei*//*swap the neighbors if out of order*/void bubble_sort(int a[], int ac){ /*use swap*/inti,j;int sign; for (j = 0; j ac-1; j++) { sign = 0; fo

文档评论(0)

1亿VIP精品文档

相关文档