美文网首页
排序之冒泡排序

排序之冒泡排序

作者: gzzzzzzz | 来源:发表于2017-08-13 13:03 被阅读0次

    冒泡排序的思想:比较相邻的两个元素的大小,如果前者比后者大,就交换这两个元素。

    假设有n个元素的话,就要比较n-1趟,第一趟比较得到最大的元素,将该元素放在数组下标为【n-1】的位置上,第二趟比较则就不用和最后一个元素比较了,比第一趟能少比较一次,将第二大的元素放在下标为【n-2】的位置上,以此类推。

    假设有如下数组arr[]:

    第一趟排序:

    判断第i个元素和第i+1个元素的大小,如果arr[i]>arr[i+1],则交换这两个元素,判断一次i++一次;直到i=size-1;

    第二趟到第n-1趟与之类似;代码实现如下:

    未优化:


    优化1:如果其中几趟没有交换元素则可以减少判断

    优化2:如果一个数组后面很多元素已经有序,只是前面元素无序,则可以只排序前面无序的元素

    相关文章

      网友评论

          本文标题:排序之冒泡排序

          本文链接:https://www.haomeiwen.com/subject/sbasrxtx.html