原创

排序——冒泡排序

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://linsh-tech.blog.csdn.net/article/details/51540899

定义:

        冒泡排序的基本思想就是:比较相邻的元素大小,将小的前移,大的后移,就像水中的气泡一样,最小的元素经过几次移动,最终浮到水面上。最终的顺序是从小到大的排序。


步骤:        

        假设当前要排序的无序数组的长度为N,要实现排序的步骤如下:

        1.比较相邻的两个数据,如果前面的数据大于后面的,则交换两者的位置,否则则不交换;

        2.对数组中从第0个元素到第N-1个元素进行一次遍历之后,最小的数据就“浮”到了数组的第0个位置;

        3.设置起点位置为1,继续前面两步操作,直到N = N-1则表示排序完成。

        


C语言实现:

1.最基本的实现方式:

        for (int i=0; i<v.size(); i++){
                int temp = 0;
                for(int j=v.size()-1; j>0; j--){
                        if (v[j] < v[j-1]){
                                temp = v[j];
                                v[j] = v[j-1];
                                v[j-1] = temp;
                        }
                }
        }

2.优化:

        其实,假如有一趟排序中没有发现需要交换位置的气泡,则说明排序已经完成,因为冒泡排序过程可以在此趟排序后终止,用一个布尔值来标识一次循环排序中是否有位置交换,代码如下:

        for (int i=0; i<v.size(); i++){
                int temp = 0;
                exchange = false;
                for(int j=v.size()-1; j>0; j--){
                        if (v[j] < v[j-1]){
                                temp = v[j];
                                v[j] = v[j-1];
                                v[j-1] = temp;
                                exchange = true;
                        }
                }
                if (!exchange){
                        break;
                }
        }


总结:

        每次排序都使有序区增加一个气泡,在经过n-1次排序之后,有序区就有n-1个气泡,而无序区中的气泡重量(数值大小)总是大于等于有序区中气泡的重量,所以整个冒泡排序过程之多需要进行n-1次排序。此算法的时间复杂度为:O(n*n),不算高效的算法。

文章最后发布于: 2016-05-30 21:02:23
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 书香水墨 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览