码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 912.排序数组(快排)


    给你一个整数数组 nums,请你将该数组升序排列。

    示例 1:

    输入:nums = [5,2,3,1]
    输出:[1,2,3,5]
    示例 2:

    输入:nums = [5,1,1,2,0,0]
    输出:[0,0,1,1,2,5]

    快速排序是先将一个元素排好序,然后再将剩下的元素排好序。

    思路:快速排序的正确理解方式及运用 

    先对数组nums进行随机洗牌,得到无序数组;然后开始快排(先序遍历、自顶向下),

    用 partition 函数把 nums[p] 这个元素排到正确的位置(左边都比它小,右边都比它大——二叉搜

    索树),然后对[low,p-1]、[p+1,high]这两个子数组进行递归,用 partition 函数把剩下的元素也

    排好序。

    随机洗牌:洗牌算法详解:你会排序,但你会打乱吗?

    1. class Solution {
    2. public:
    3. vector<int> sortArray(vector<int>& nums)
    4. {
    5. shuffle(nums);//随机洗牌
    6. sort(nums,0,nums.size()-1);
    7. return nums;
    8. }
    9. void shuffle(vector<int>& nums)
    10. {
    11. srand(time(NULL));
    12. int n=nums.size();
    13. for(int i=0;i//产生n!种可能
    14. {
    15. int index=i+rand()%(n-i);//随机生成[i,n-1]范围内的一个数作为数组下标
    16. swap(nums,i,index);
    17. }
    18. }
    19. void swap(vector<int>& nums,int i,int index)
    20. {
    21. int tmp=0;
    22. tmp=nums[i];
    23. nums[i]=nums[index];
    24. nums[index]=tmp;
    25. }
    26. void sort(vector<int>& nums,int low,int high)
    27. {
    28. if(low>=high)
    29. return ;
    30. //对nums[low..high]进行切分,使得nums[low..p-1]<=nums[p]
    31. int p=partition(nums,low,high);
    32. sort(nums,low,p-1);
    33. sort(nums,p+1,high);
    34. }
    35. int partition(vector<int>& nums,int low,int high)
    36. {
    37. int pivot=nums[low];//以第一个元素作为枢轴
    38. int i=low+1,j=high;
    39. while(i<=j)
    40. {
    41. while(i//此while结束时恰好nums[i]>pivot
    42. {
    43. i++;
    44. }
    45. while(j>low&&nums[j]>pivot)//此while结束时恰好nums[j]<=pivot
    46. {
    47. j--;
    48. }
    49. if(i>=j)//如果i>=j,跳出循环,j的位置就是pivot应该被放到的正确位置
    50. {
    51. break;
    52. }
    53. swap(nums,i,j);//交换不符合枢轴左边小、右边大规则的两个元素
    54. }
    55. swap(nums,low,j); //将pivot放到合适的位置,即pivot左边元素小,右边元素大
    56. return j;//返回pivot的位置
    57. }
    58. };

  • 相关阅读:
    【源码课件+名师讲解】Java企业级项目实战_livegoods房屋海选平台_Java前后端分离架构微服务项目实战_Java课程设计_Java毕业设计
    Excel如何设置密码保护【图文详情】
    Three.js相机模拟
    C语言超好看的爱心代码!一定不要错过!
    【数据结构】单链表的增删查改
    并发原理 — CPU原子性指令(一)
    接口测试总结分享(http与rpc)
    protobuf相关安装
    springboot实验室自主预约系统毕业设计源码111953
    【Vue3】动态 class 类
  • 原文地址:https://blog.csdn.net/weixin_50437588/article/details/126215416
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号