码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 排序-快排算法对数组进行排序


    目录

    一、问题描述

    二、解题思路

    1.初始化

    2.将右侧小于基准元素移到左边

    3.将左侧大于基准元素移到右边

    4.重复执行上面的操作

    5.对分好的左、右分区再次执行分区操作

    6.最终排序结果

    三、代码实现

    四、刷题链接


    一、问题描述

    二、解题思路

    快排算法实现数组排序:快排的核心步骤是分区操作。

    下面详细图解一次分区过程:

    1.初始化

    2.将右侧小于基准元素移到左边

    赋值后相当于下面的情形:

    3.将左侧大于基准元素移到右边

    然后开始比较arr[low]和pivot的大小:(和上图作对比)

    赋值后的数组为:

    4.重复执行上面的操作

    再次修改high(左移--),移动元素,再次修改low(右移++),移动元素;当low==high时停止,完成一次分区操作:

    5.对分好的左、右分区再次执行分区操作

    分区返回的是中间元素位置,我们要对左、右两个子分区再次执行分区操作,每次分区都会确定一个中间位置(后序不会再变),当分区内元素都为1的时候,快排结束。

    6.最终排序结果

    三、代码实现

    1. import java.util.*;
    2. public class Solution {
    3. /**
    4. * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
    5. *
    6. * 将给定数组排序
    7. * @param arr int整型一维数组 待排序的数组
    8. * @return int整型一维数组
    9. */
    10. public int[] MySort (int[] arr) {
    11. // 使用快排排序
    12. QuickSort(arr,0,arr.length-1);
    13. return arr;
    14. }
    15. public int partition(int[] arr,int low,int high){
    16. int pivot=arr[low];//分界元素
    17. //System.out.println("low:"+low+",high:"+high);
    18. while(low
    19. while(arr[high]>=pivot){//右侧元素大于pivot不移动
    20. if(low==high){
    21. break;
    22. }
    23. high--;
    24. }
    25. arr[low]=arr[high];//现在的arr[high]已经没有元素了
    26. while(arr[low]<=pivot){//左侧元素小于等于pivot不移动
    27. if(low==high){
    28. break;
    29. }
    30. low++;
    31. }
    32. arr[high]=arr[low];
    33. }
    34. //此时low位置就是初始的分界元素应该在的位置
    35. arr[low]=pivot;
    36. return low;
    37. }
    38. public void QuickSort(int[] arr,int low,int high){
    39. int pivotIndex=partition(arr,low,high);
    40. if(low1){
    41. QuickSort(arr,low,pivotIndex-1);
    42. }
    43. if(high>pivotIndex+1){
    44. QuickSort(arr,pivotIndex+1,high);
    45. }
    46. }
    47. }

    快排算法里面要注意边界条件,这个好好思考一下。

    如果考研的话可以写伪代码,边界条件可以考虑的少一点

    排序算法相关代码-CSDN博客文章浏览阅读108次。【代码】排序算法相关代码。https://blog.csdn.net/hehe_soft_engineer/article/details/134235961下面是之前写的排序算法的C++实现,属于伪代码,应试的话可以参考一下:

    四、刷题链接

    排序_牛客题霸_牛客网

  • 相关阅读:
    格林公式推导
    @Autowired注解推荐使用方法:用在构造方法上
    学习心得08:OpenGL
    两种MySQL OCP认证应该如何选?
    一文看懂 ZooKeeper ,面试再也不用背八股
    码蹄杯 2024 初赛第一场
    How to record the screen on your Mac
    Spring入门须知
    基于最小二乘支持向量机(LS-SVM)进行分类、函数估计、时间序列预测和无监督学习附Matlab代码
    Postgresql14安装及主从配置
  • 原文地址:https://blog.csdn.net/hehe_soft_engineer/article/details/139578152
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号