码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • //快速排序的非递归版本


    //快速排序的非递归版本
    1. package quickSort;
    2. import java.util.Stack;
    3. /**
    4. * @author 真他喵的学不动咯
    5. * @create 2022-08-19--20:52
    6. */
    7. public class quictwo { //快速排序的非递归版本
    8. public static class Job{
    9. public int L;
    10. public int R;
    11. public Job(int left,int right){
    12. L=left;
    13. R=right;
    14. }
    15. }
    16. //分层【用了递归】
    17. public static int[] partition(int[] arr, int L, int R){
    18. /*
    19. arr[L,...,R],arr[R做划分值
    20. L......R
    21. < = >
    22. */
    23. int lessR=L-1; //L-1为左边预备区域
    24. int moreL=R; //R是右边第一区域
    25. int index=L; //L是左边第一轮开始的地方,从L开始遍历
    26. while (index<moreL){
    27. if (arr[index]<arr[R]){
    28. swap(arr,++lessR,index++);
    29. }
    30. else if (arr[index]>arr[R]){
    31. swap(arr,--moreL,index);
    32. }else{
    33. index++;
    34. }
    35. }
    36. swap(arr,moreL,R); //moreL和最后一个数进行了交换,所以下一句直接就是moreL,而不是moreL-1
    37. return new int[]{lessR+1,moreL}; //lessR+1 是等于区域的第一个,moreL是等于区域的最后一个
    38. }
    39. public static void swap(int[] arr,int i,int j){
    40. int temp=arr[i];
    41. arr[i]=arr[j];
    42. arr[j]=temp;
    43. }
    44. public static void quicksort2(int[] arr){
    45. if (arr==null||arr.length<2){
    46. return;
    47. }
    48. Stack<Job> stack=new Stack<>(); //把Job放入栈
    49. stack.push(new Job(0,arr.length-1)); //在0~N上排序
    50. while (!stack.isEmpty()){ //栈中不为空,就一直做
    51. Job cur=stack.pop();
    52. int L=cur.L;
    53. int R=cur.R;
    54. int[] equals=partition(arr,L,R); //知道左任务、右任务,在栈然后一直做
    55. //equals返回等于区域
    56. if (equals[0]>cur.L){ //此时有小于区域
    57. stack.push(new Job(cur.L,equals[0]-1));
    58. }
    59. if (equals[1]<cur.R){ //此时有大于区域
    60. stack.push(new Job(equals[1]+1,R));
    61. }
    62. }
    63. }
    64. }

  • 相关阅读:
    Spring5学习笔记
    minio分布式文件存储 windows部署 和 api 使用
    c++ c语言学习之 取反 ~
    Python算法图解——递归(二):打印从10循环到1
    Attention-based LSTM for Aspect-level Sentiment Classification
    五分钟 k8s入门到实战--跨服务调用
    CSS 使用
    zookeeper集群部署安装
    WordPress Mixed Content混合内容警告:4 种简单的修复方法
    MySQL 默认隔离级别是RR,为什么阿里等大厂会改成RC?
  • 原文地址:https://blog.csdn.net/weixin_48752513/article/details/126431895
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号