排序之冒泡排序

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

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

假设有如下数组arr[]:

第一趟排序:

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

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

未优化:


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

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


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容