码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 单边循环的快排


    快排很多,但是适合自己的就是最好的,这个思想很重要,我分享一个自己一直用的一个思想。

    递归肯定是需要的,单边循环三步走

    1.先存储 pivot中心值

    2.从右边开始找比中心值(pivot)小的数,然后放在左边的下标的位置

    3.从左边开始找比中心值(pivot)大的数,然后放到右边下标的位置

     突然想分享这个是因为,在面试字节的时候,做某道题目的时候,在其中某步骤排序的时候,面试官不让用库里面的函数,然后手撕的算法也没有写完,这个事件对我触动很深,一定要将基本算法打扎实!

    下面给出我的代码实现:

    1. package com.codeking.exam;
    2. /**
    3. * @author xiongjl
    4. * @since 2023/9/25 21:36
    5. */
    6. public class quickSortTest {
    7. public static void main(String[] args) {
    8. int[] nums = {5, 5, 7, 1, 0, 5, 6, 9, 4, 7};
    9. quickSort(nums, 0, nums.length-1);
    10. for (int num : nums) {
    11. System.out.print(num);
    12. }
    13. }
    14. static void quickSort(int[] nums, int l, int r) {
    15. if (l >= r) return;
    16. int left = l, right = r;
    17. int pivot = nums[l];
    18. while (left < right) {
    19. while (left < right && nums[right] >= pivot) right--;
    20. if (left < right && nums[right] < pivot) nums[left] = nums[right];
    21. while (left < right && nums[left] <= pivot) left++;
    22. if (left < right && nums[left] > pivot) nums[right] = nums[left];
    23. }
    24. nums[left] = pivot;
    25. quickSort(nums, l, right - 1);
    26. quickSort(nums, right + 1, r);
    27. }
    28. }

  • 相关阅读:
    Python基于Django的电影推荐系统和论坛项目完整源码
    java毕业设计—— 基于java+JavaEE+jsp的售后服务管理系统设计与实现(毕业论文+程序源码)——售后服务管理系统
    企业数字化办公利器——华为云桌面Workspace
    【gradle】idea创建的gradle项目每个mudule有多余的iml文件
    Linux 将 /home 目录与 / 根目录磁盘合并
    外置告警蜂鸣器使用小坑
    7--OpenCV:图像基本操作之①截取②掩膜 操作
    springboot设置并获取启动参数
    Web前端开发基础笔记(6)
    英飞凌Tricore原理及应用介绍06_系统定时器(STM)模块详解
  • 原文地址:https://blog.csdn.net/weixin_45686265/article/details/133281250
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号