1.概念
冒泡排序(Bubble Sort)又称泡式排序,是一种简单的排序算法
核心思想:它重复地走访过要排列的次数,一次比较两个元素,如果它们的顺序错误就把它们交换过来,走访数列的工作是重复地进行交换直到不需要交换为止,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或者降序排列),就像水中的气泡会冒起来一样
步骤:
- 比较相邻的元素,如果第一个比第二个大。就交换它们两个
 - 对每一对相邻的元素做同样的工作,从一开始第一对到结尾的最后一对,这步做完后,最后的元素会是最大的数
 - 针对所有的元素重复以上的步骤,除了最后一个
 - 持续每次多越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较
 

想必一幅图大家已经基本看懂冒泡排序的原理
具体实现:使用双重循环,外层循环控制循环的次数,内层循环进行数字的比较,内层每一次循环结束之后,都要找出最大的数据,放到参与比较的这堆数据的最右边,下次循环不再比较该数
    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.length; i++) {
            for (int j = 0; j<i ; j++) {
                if(nums[j]>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<stones.length-1; i++) {
             bubbleSort(stones);
          if (stones[n - 1] == 0) break;           //说明最多只剩一块石头
             stones[n] -= stones[n - 1];          //两种不同情况使用同一表达式处理
             stones[n - 1] = 0;   
        }
        return stones[n];
    } 
元素计数
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(i<j){
            while(i<j&&num[j]>povit){
                j--;
            }
            if(i<j){
                num[i++]=num[j];
            }
            while(i<j&&num[i]<povit){
                i++;
            }
            if(i<j){
                num[j--]=num[i];
            }
        }
        num[i]=povit;
        fastSort(num,i+1,right);
        fastSort(num,left,i-1);
    }
    public int countElements(int[] nums) {
      if(nums==null||nums.length==0){
          return 0;
      }
      //将原数组进行排序
      fastSort(nums,0,nums.length-1);
      int ans=0;
        for (int i = 0; i < nums.length; i++) {
            if(nums[i]==nums[0]||nums[i]==nums[nums.length-1]){
                continue;
            }
            ans++;
        }
        return ans;
    }
} 
合并两个有序数组
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(i<j){
            while(i<j&&num[j]>povit){
                j--;
            }
            if(i<j){
                num[i++]=num[j];
            }
            while(i<j&&num[i]<povit){
                i++;
            }
            if(i<j){
                num[j--]=num[i];
            }
        }
        num[i]=povit;
        fastSort(num,i+1,right);
        fastSort(num,left,i-1);
    }
    public int maxProduct(int[] nums) {
     if(nums==null||nums.length==0){
         return 0;
     }
     fastSort(nums,0,nums.length-1);
     return (nums[nums.length-1]-1)*(nums[nums.length-2]-1);
    }
} 
                














![[深入理解NAND Flash] 闪存(NAND Flash) 学习指南](https://img-blog.csdnimg.cn/a2555b3d39a44b1d9c5b1a22d01ceaa2.png)



