首页 > 其他分享 >冒泡排序与快速排序

冒泡排序与快速排序

时间:2024-06-02 09:28:42浏览次数:25  
标签:par arrary return int 冒泡排序 right 排序 快速 left


 博主主页: 码农派大星.

    数据结构专栏:Java数据结构

 数据库专栏:MySQL数据库

关注博主带你了解更多数据结构知识


1.冒泡排序

<iframe allowfullscreen="true" data-mediaembed="csdn" frameborder="0" id="SSOGW9S0-1717039073076" src="https://live.csdn.net/v/embed/394384"></iframe>

冒泡排序

private static void swap(int[] arrary,int i,int j){
        int tmp = arrary[i];
        arrary[i] = arrary[j];
        arrary[j] = tmp;

public static void  bubbleSort(int[] arrary){
        for (int i = 0; i <arrary.length-1 ; i++) {
            for (int j = 0; j < arrary.length-1-i; j++) {
                if(arrary[j]> arrary[j+1]){
                    swap(arrary,j,j+1);
                }

            }
        }
        return arrary;
    }

冒泡排序总结

1. 冒泡排序是一种非常容易理解的排序

2. 时间复杂度:O(N^2)

3. 空间复杂度:O(1)

4. 稳定性:稳定 

2.快速排序

快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,其基本思想为:任取待排序元素序列中的某元 素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值,右子序列中所有 元素均大于基准值,然后最左右子序列重复该过程,直到所有元素都排列在相应位置上为止。

1.Hoare版

public static void  quickSort(int[] arrary){
        quick(arrary,0,arrary.length-1);
        return arrary;

    }
    private static void swap(int[] arrary,int i,int j){
        int tmp = arrary[i];
        arrary[i] = arrary[j];
        arrary[j] = tmp;
    private static void quick(int [] arrary,int start,int end){
        if (start >= end) {
            return;
        }
        int par = partition(arrary,start,end);
        quick(arrary,start,par-1);
        quick(arrary,par+1,end);
    }
    private static int partition(int [] arrary,int left,int right){
        int i = left;
        int tmp = arrary[left];
        while (left < right){
            //right-- : 先走左边会导致最后相遇的地方比基准大的数据,
            // 交换完后,会把大于基准的值换到前面
            while (left < right && arrary[right] >= tmp){
                right--;
            }
            while (left < right && arrary[left] <= tmp){
                left++;
            }
            swap(arrary,left,right);
        }
        //此时相遇left=right;
        swap(arrary,left,i);
        return right;
    }

2.挖坑法 

public static void  quickSort(int[] arrary){
        quick(arrary,0,arrary.length-1);
        return arrary;

    }
private static void quick(int [] arrary,int start,int end){
        if (start >= end) {
            return;
        }
        int par = partitionWaken(arrary,start,end);
        quick(arrary,start,par-1);
        quick(arrary,par+1,end);
    }
private static int partitionWaken(int [] arrary,int left,int right){
        int tmp = arrary[left];
        while (left<right){
            while (left < right && arrary[right] >= tmp){
                right--;
            }
            arrary[left] = arrary [right];
            while (left<right && arrary[left] <= tmp){
                left++;
            }
            arrary[right] = arrary[left];
        }
        arrary[left] = tmp;
        return left;
    }

3.快速排序优化

1. 三数取中法选key


 public static void  quickSort(int[] arrary){
        quick(arrary,0,arrary.length-1);
return arrary;

    }
    private static void quick(int [] arrary,int start,int end){
        if (start >= end) {
            return;
        }

        int index = midThreeNum(arrary,start,end);
        swap(arrary,index,start);

        int par = partitionWaken(arrary,start,end);
        quick(arrary,start,par-1);
        quick(arrary,par+1,end);
    }

private static int partitionWaken(int [] arrary,int left,int right){
        int tmp = arrary[left];
        while (left<right){
            while (left < right && arrary[right] >= tmp){
                right--;
            }
            arrary[left] = arrary [right];
            while (left<right && arrary[left] <= tmp){
                left++;
            }
            arrary[right] = arrary[left];
        }
        arrary[left] = tmp;
        return left;
    }
    private static int midThreeNum(int [] arrary,int left,int right){
        int mid = (left+right)/2;
        if (arrary[left] < arrary[right]){
            if (arrary[mid] < arrary[left]) {
                return left;

            }else if (arrary[mid] > arrary[right]){
                return right;
            }else {
                return mid;
            }
        }else{
            if (arrary[mid] < arrary[right]){
                return right;
            }else if(arrary[mid] > arrary[left]){
                return left;
            }else {
                return mid;
            }
        }
    }

2. 递归到小的子区间时,可以考虑使用插入排序

我们在数组中数据小于等于10时改为插入排序,提高了排序的效率.

 public static void  quickSort(int[] arrary){
        quick(arrary,0,arrary.length-1);
return arrary;

    }
    private static void quick(int [] arrary,int start,int end){
        if (start >= end) {
            return;
        }
        if (end - start + 1 <= 10) {
            inserSortRange(arrary,start,end);
            return;
        }

        int index = midThreeNum(arrary,start,end);
        swap(arrary,index,start);

        int par = partitionWaken(arrary,start,end);
        quick(arrary,start,par-1);
        quick(arrary,par+1,end);
    }
    public static  void inserSortRange(int [] array,int left,int right){
        for(int i = left+1; i< right;i++){
            int tmp = array[i];
            int j = i-1;
            for (; j >=0 ; j--) {
                if (array[j] > tmp) {
                    array[j+1] = array[j];
                }else {
                    //array[j+1]= tmp;
                    break;
                }
            }
            array[j+1]= tmp;
        }
    }
 private static int partitionWaken(int [] arrary,int left,int right){
        int tmp = arrary[left];
        while (left<right){
            while (left < right && arrary[right] >= tmp){
                right--;
            }
            arrary[left] = arrary [right];
            while (left<right && arrary[left] <= tmp){
                left++;
            }
            arrary[right] = arrary[left];
        }
        arrary[left] = tmp;
        return left;
    }
    private static int midThreeNum(int [] arrary,int left,int right){
        int mid = (left+right)/2;
        if (arrary[left] < arrary[right]){
            if (arrary[mid] < arrary[left]) {
                return left;

            }else if (arrary[mid] > arrary[right]){
                return right;
            }else {
                return mid;
            }
        }else{
            if (arrary[mid] < arrary[right]){
                return right;
            }else if(arrary[mid] > arrary[left]){
                return left;
            }else {
                return mid;
            }
        }
    }

4.非递归的快速排序 

//非递归快速排序
 
    public static void quickNot(int[] array){
        Stack<Integer> stack = new Stack<>();
        int left = 0;
        int right = array.length - 1;
        int par = partition(array,left,right);
        if (par > left+1){
            stack.push(left);
            stack.push(par-1);

        }
        if (par < right-1){
            stack.push(par+1);
            stack.push(right);
        }
        while (!stack.isEmpty()){
            right = stack.pop();
            left = stack.pop();
            par = partitionWaken(array,left,right);
            if(par > left+1){
                stack.push(left);
                stack.push(par-1);
            }
            if (par < right -1){
                stack.push(par+1);
                stack.push(right);
            }
        }
         return array;
    }
private static int partition(int [] arrary,int left,int right){
        int i = left;
        int tmp = arrary[left];
        while (left < right){
            //right-- : 先走左边会导致最后相遇的地方比基准大的数据,
            // 交换完后,会把大于基准的值换到前面
            while (left < right && arrary[right] >= tmp){
                right--;
            }
            while (left < right && arrary[left] <= tmp){
                left++;
            }
            swap(arrary,left,right);
        }
        //此时相遇left=right;
        swap(arrary,left,i);
        return right;
    }

未优化的快速排序,再遇到数据过多时,程序会崩. 

1. 快速排序整体的综合性能和使用场景都是比较好的,所以才敢叫快速排序

2. 时间复杂度:O(N*logN)

快速排序和堆排序时间复杂度一样,但是快速排序要比堆排序快

3. 空间复杂度:O(logN)

4. 稳定性:不稳定

标签:par,arrary,return,int,冒泡排序,right,排序,快速,left
From: https://blog.csdn.net/jj666mhhh/article/details/139318786

相关文章

  • 【JAVA】快速遍历map集合
    1.使用entrySet()方法【推荐】2.直接使用values()方法获取所有value值组成的集合3.使用keySet()方法和getValue方法4.使用迭代器iterator5.使用增强for的Lambda表达式......
  • Q3 LeetCode34 在排序数组中找起始位置
    提交错误:数组访问越界1.验证数组越界的语句要放在执行语句的前面,要不然前面报错无法进行到后面部分2.本题使用两次二分查找,左边界找到后,将rigiht指针设置成mid-1,继续查找更左的边界,右边界同理将left设置成mid+13.newint[]{1,1}  新数组创建方式 1classSolution{......
  • 格式刷不能跨工作薄使用,VBA自建公式快速获取 单元格背景色RGB值
    查看视频效果请点击文章目录前言1.数字转字母代码:2.获取单元格背景颜色RGB值代码:前言格式刷在我们调整Excel工作表、Word文档的格式时经常使用到,它可以帮助我们快速批量调整字体、大小、颜色、背景色等,甚至是表格行高列宽、字间距大小等。但如果在不同的......
  • 全面战争模拟器steam_api64.dll丢失怎么解决?全面战争模拟器steam_api64.dll丢失问题的
    steam_api64.dll是一个关键的动态链接库(DLL)文件,专用于64位Windows操作系统上的Steam平台。那么全面战争模拟器steam_api64.dll丢失怎么解决呢?下面一起来看看吧!还原回收站中的文件如果您之前不小心删除了steam_api64.dll文件,可以在回收站中找到该文件,并尝试将其还原到原来的......
  • [排序算法]选择排序+堆排序全梳理!
    目录前言1.直接选择排序基本思想具体步骤:动图演示代码实现直接选择特性总结:2.堆排序向下调整算法任意树调整为堆的思想堆排序堆排序的基本思想:动图演示选择排序的特性总结:3.总结前言今天我们将学习排序算法中的直接选择排序和堆排序,它们的基本思想都是每一......
  • delphi Image32 之 快速入门
     官方快速入门,加上了一些注解[从WORD粘贴后失去了样式]TImage32类是关键。TImage32 对象包含单个图像,所有图像操作都作用于此对象。usesImg32; //引用单元...img:=TImage32.Create; //创建TImage32对象//执行一些其它操作img.Free; //用完了要释放图像存储......
  • 冒泡排序
    //通过指针交换两个元素的值voidswap(int*a,int*b){inttemp=*a;*a=*b;*b=temp;}/*****************************************************************name;BubbleSort*function:sort*parameter;*@intarr[]*......
  • 共享门店+助力小微企业快速成型的催化剂
    共享门店+股东分红模式一、模式概述共享门店+股东分红模式是一种结合了共享经济和传统实体门店的新型商业模式。在这种模式下,多个品牌或商家共同使用同一门店空间,通过共享资源、资金和客户资源,降低经营成本,提高资源利用效率,扩大市场渠道,同时,股东们可以根据其持股比例享受门店......
  • Python教程-快速入门基础必看课程05-List索引
    摘要该视频主要讲述了Python中列表的基本操作,包括创建、添加元素、查找特定值、计算元素数量以及获取最后一个元素等。视频以清晰的例子和解释来展示这些操作,非常有助于初学者理解。此外,视频还讲述了Python中索引和切片的使用方法,这些是Python中非常重要的基础概念。掌握这些......
  • 博饼上快速路由是什么意思
    引言:很多小伙伴在操作的时候看到这个快速路由啥意思有点不清楚官方的解释:简单说:举个列子:如果我交易的是BNB-CAKE,如果目前池子里面没有、当你又勾选了快速路由,那么如果池子里面有bnb-usdt和usdt-cake,也能根据usdt这个兑换过去。明白了不,如果你不勾选快速路由、......