• 【排序】详解冒泡排序


    一、思想

    冒泡排序的基本思想是利用两两比较相邻记录的方式,通过一系列的比较和交换操作,使得较大或较小的元素逐渐移动到数列的一端。在每一轮的排序过程中,都会从数列的起始位置开始,对相邻的元素进行比较,如果它们的顺序不符合要求(例如,前一个元素大于后一个元素),则交换它们的位置。这样,每轮遍历后,至少会有一个元素被移动到其最终位置。重复这个过程,直到没有任何一对元素需要交换位置,即整个数组变为有序。

    冒泡排序的过程可以形象地比喻为水中的气泡上升过程,较小的元素逐渐“冒”到数列的顶端,而较大的元素则沉到底部。这个过程就像是在水中的气泡一样,不断向上冒出,直到所有的气泡都排好序。

    冒泡排序的时间复杂度为O(n^2),这使得它在处理大规模数据时效率不高。尽管如此,由于其实现简单,对于小规模数据集或者基本有序的数组,冒泡排序仍然是一个不错的选择。

    二、图解

    i指针控制次数,j指针每次遍历时进行两两比较,j每遍历一遍都会将一个最大的数排好序

    依次重复上述步骤,直到j遍历完n-1遍。如果一个数组本来就是有序或者经过小于n-1次就已经排好了序,那么j指针后续的遍历就是徒劳,所以我们可以根据j指针在遍历过程中是否有交换进行判断,如果没有交换说明已经排好序,这个时候就可直接返回

    三、代码实现
    1. void bubble_sort(vector<int>& arr) {
    2. for (int i = 0; i < arr.size(); i++) {
    3. bool f = false;
    4. for (int j = 0; j < arr.size() - i - 1; j++) {
    5. if (arr[j] > arr[j + 1]) {
    6. swap(arr[j], arr[j + 1]);
    7. f = true;
    8. }
    9. }
    10. if (!f) return;
    11. }
    12. }
    1. public static void bubbleSort(int[] arr) {
    2. for (int i = 0; i < arr.length; i++) {
    3. boolean f = true;
    4. for (int j = 0; j < arr.length - i - 1; j++) {
    5. if (arr[j] > arr[j + 1]) {
    6. f = false;
    7. swap(arr, j, j + 1);
    8. }
    9. }
    10. if (f) {
    11. break;
    12. }
    13. }
    14. }
  • 相关阅读:
    ModuleNotFoundError: No module named ‘sklearn.cross_validation‘
    C语言8道大厂指针笔试题——拿捏指针
    npm改变npm缓存路径和改变环境变量
    【Java集合类面试二十四】、ArrayList和LinkedList有什么区别?
    gcc编译选项
    【HBZ分享】ES中的DLS命令使用
    接口自动化测试要做什么?一文3个步骤带你成功学会!
    UE5.1 + Android 环境搭建
    [算法周训 2]字符串训练1
    java计算机毕业设计基于springboot人职匹配推荐系统
  • 原文地址:https://blog.csdn.net/qq_61903414/article/details/136487153