zoukankan      html  css  js  c++  java
  • 排序-冒泡排序

    解题步骤:

    1. 使用for循环(外层循环),指定数组要循环的圈数(通过图解可知,数组循环的圈数为数组长度 - 1)
    2. 在每一圈中,通过for循环(内层循环)完成相邻的元素值依次比较,把大的值放后面的元素中
    3. 每圈内层循环的次数,由第几圈循环来决定。如上图所示

    a)进行第一圈元素比较时,内层循环次数为数组长度 - 1

    b) 进行第二圈元素比较时,内层循环次数为数组长度 - 2

    c)依次类推,得出结论:进行第n圈元素比较时,内层循环次数为数组长度 - n

    //冒泡排序
    public static void bubbleSort(int[] arr) {
        //功能
        //外层循环用来控制数组循环的圈数
        for (int i = 0; i < arr.length-1; i++) {
            //j < arr.length-1 为了避免角标越界
            //j < arr.length-1-i 为了比较效率,避免重复比较
            //内层循环用来完成元素值比较,把大的元素值互换到后面
            for (int j = 0; j < arr.length-1-i; j++) {
                if (arr[j] > arr[j+1]) {
                    int temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = temp;
                }
            }
        }
    }
  • 相关阅读:
    mysql数据库中的锁
    HihoCoder
    旅游规划(双权连通图)
    单调栈的原理
    战争联盟(并查集)
    点赞狂魔(巧用STL容器事半功倍)
    这是二叉搜索树吗?
    好像是两种权的dijkstra
    pat--046.整除光棍(除法模拟)
    幸运数字 2
  • 原文地址:https://www.cnblogs.com/aeolian/p/9524226.html
Copyright © 2011-2022 走看看