一起学算法(冒泡排序篇)

1.概念

冒泡排序(Bubble Sort)又称泡式排序,是一种简单的排序算法

核心思想:它重复地走访过要排列的次数,一次比较两个元素,如果它们的顺序错误就把它们交换过来,走访数列的工作是重复地进行交换直到不需要交换为止,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或者降序排列),就像水中的气泡会冒起来一样

步骤:

  • 比较相邻的元素,如果第一个比第二个大。就交换它们两个
  • 对每一对相邻的元素做同样的工作,从一开始第一对到结尾的最后一对,这步做完后,最后的元素会是最大的数
  • 针对所有的元素重复以上的步骤,除了最后一个
  • 持续每次多越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较

一起学算法(冒泡排序篇)_第1张图片

 想必一幅图大家已经基本看懂冒泡排序的原理

具体实现:使用双重循环,外层循环控制循环的次数,内层循环进行数字的比较,内层每一次循环结束之后,都要找出最大的数据,放到参与比较的这堆数据的最右边,下次循环不再比较该数

    public void bubbleSort(int[] arr) {
        //入参进行判断
        if (arr == null || arr.length == 0) {
            return;
        }
        //每次确定无序列表中最大的,从右往左
        for (int i = 1; i < arr.length; i++) { // 表示进行的轮数
            //比较的次数是数组的总长度减去已经排好序的长度
            for (int j = 0; j < arr.length - i; j++) { 
               //两两进行比较,直到长度完结
                if (arr[j] > arr[j + 1]) {
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }

leetcode题单:

最后一块石头

 //冒泡排序
    public void bubbleSort(int [] nums){
        if(nums==null||nums.length==0){
            return;
        }
        for (int i =1; i nums[j+1]){
                    int temp=nums[j];
                    nums[j]=nums[j+1];
                    nums[j+1]=temp;
                }
            }
        }
    }

    public int lastStoneWeight(int[] stones) {
        if(stones==null||stones.length==0){
            return 0;
        }
        int n=stones.length-1;
        for (int i =0; i

元素计数

class Solution {
    //快排   冒泡排序也可以做
    public void fastSort(int [] num,int left,int right){
        if(left>=right){
            return;
        }
        if(num==null||num.length==0){
            return;
        }
        int povit=num[left];
        int i=left;
        int j=right;
        while(ipovit){
                j--;
            }
            if(i

合并两个有序数组

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
int[] arr = new int[m + n];
        int i = 0;
        int j = 0;
        int index = 0;
        // 进行比较
        while (i < m && j < n) {
            if (nums1[i] < nums2[j]) {
                arr[index++] = nums1[i];
                i++;
            } else {
                arr[index++] = nums2[j];
                j++;
            }
        }

        while (i < m) {
            arr[index++] = nums1[i];
            i++;
        }
        while (j < n) {
            arr[index++] = nums2[j];
            j++;
        }
        // 反向填充
        for (int k = 0; k < m + n; k++) {
            nums1[k] = arr[k];
        }


    }
}

数组中两元素的最大乘积

class Solution {
    //快排   冒泡排序也同样可以做
    public void fastSort(int [] num,int left,int right){
        if(left>=right){
            return;
        }
        if(num==null||num.length==0){
            return;
        }
        int povit=num[left];
        int i=left;
        int j=right;
        while(ipovit){
                j--;
            }
            if(i

你可能感兴趣的:(一起学算法,算法)