【912.排序数组】
目录
- 一、题目描述
- 二、算法原理
- 2.1快速排序
- 2.2归并排序
- 三、代码实现
- 3.1快排代码实现
- 3.2归并代码实现
一、题目描述

二、算法原理
2.1快速排序

2.2归并排序

三、代码实现
3.1快排代码实现
class Solution {
public:int getRandom(int left,int right,vector<int>& nums){return nums[rand()%(right-left+1)+left];}void _sortArray(int left,int right,vector<int>& nums){if(left>right){return ;}int key=getRandom(left,right,nums);int l=left-1,r=right+1,i=left;while(i<r){if(nums[i]<key)swap(nums[++l],nums[i++]);else if(nums[i]>key)swap(nums[i],nums[--r]);elsei++;}_sortArray(left,l,nums);_sortArray(r,right,nums);}vector<int> sortArray(vector<int>& nums) {srand(time(NULL));_sortArray(0,nums.size()-1,nums);return nums;}
};
3.2归并代码实现
class Solution {
public:void mergeSort(vector<int>& nums,int left,int right){if(left>=right){return;}int mid=left+(right-left)/2;mergeSort(nums,left,mid);mergeSort(nums,mid+1,right);//合并两个有序数组vector<int> v(right-left+1);int cur1=left,cur2=mid+1,i=0;while((cur1<=mid)&&(cur2<=right)){if(nums[cur1]<nums[cur2]){v[i++]=nums[cur1++];}else{v[i++]=nums[cur2++];}}while(cur1<=mid) v[i++]=nums[cur1++];while(cur2<=right) v[i++]=nums[cur2++];//还原数组for(int i=left;i<=right;i++){nums[i]=v[i-left];}}vector<int> sortArray(vector<int>& nums) {mergeSort(nums,0,nums.size()-1);return nums;}
};
相关文章:
【912.排序数组】
目录 一、题目描述二、算法原理2.1快速排序2.2归并排序 三、代码实现3.1快排代码实现3.2归并代码实现 一、题目描述 二、算法原理 2.1快速排序 2.2归并排序 三、代码实现 3.1快排代码实现 class Solution { public:int getRandom(int left,int right,vector<int>&…...
【动态规划】583. 两个字符串的删除操作、72. 编辑距离
提示:努力生活,开心、快乐的一天 文章目录 583. 两个字符串的删除操作💡解题思路🤔遇到的问题💻代码实现🎯题目总结 72. 编辑距离💡解题思路🤔遇到的问题💻代码实现&…...
Gradient conjugate priors and multi-layer neural networks
动机 先验参数 m , α , β , v m,\alpha,\beta,v m,α,β,v和随机变量 τ \tau τ KL散度的形式是: Dynamics of m , α , β , v m,\alpha,\beta,v m,α,β,v Dynamics of m , β , v m,\beta,v m,β,v for a fixed α \alpha α 绿色轨迹连接初始点和目标点…...
DistributedDataParallel数据不均衡
背景 在使用 DistributedDataParallel 进行数据并行训练时,每次反向传播都需要执行 all_reduce 操作以同步各个进程的梯度。all_reduce 需要进程组中的所有进程参与,如果某一个进程没有执行 all_reduce(一个进程的输入较其他进程少ÿ…...
Cloud Studio连接MySQL,Access denied for一系列问题
官方文档有写如何安装Mysql $ apt update $ apt install mysql-server mysql-client -y$ service mysql start mysql -uroot -p123456进入MySQL命令行 问题出在连接数据库这一步,命令行能进去,但是数据库插件和代码都连不上 Access denied for 大概率…...
经典题型---旋转数组
经典题型—旋转数组 文章目录 经典题型---旋转数组一、题目二、代码实现 一、题目 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 示例 1: 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步…...
vue如何实现登录数据的持久化
Vue.js是一款流行的JavaScript框架,它可以帮助开发者构建高效且易于维护的单页面应用程序。在Vue.js中,实现登录数据的持久化是一个重要的任务,因为它可以帮助用户保持登录状态并避免频繁的登录操作。在本文中,我们将讨论Vue.js如…...
【Unity3D编辑器开发】Unity3D中实现Transform组件拓展,快速复制、粘贴、复原【非常实用】
推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址我的个人博客 大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 一、前言 在开发中,常常会遇到频繁复制粘贴物体的坐标、旋转…...
求解仿射变换矩阵
仿射变换是图形学中经常用到的方法,通常但是仿射变换的系数是未知的,需要找到变换前后的三对对应点进行求解。 from affine import Affine import numpy as np参考文献 矩阵最小二乘法求解仿射变换矩阵 def solve_affine(init_points, goal_points) -&…...
【每日一题】—— 最大素因子
🌏博客主页:PH_modest的博客主页 🚩当前专栏:每日一题 💌其他专栏: 🔴 每日反刍 🟡 C跬步积累 🟢 C语言跬步积累 🌈座右铭:广积粮,缓称…...
【JavaEE】JUC 常见的类 -- 多线程篇(8)
JUC 常见的类 1. Callable 接口2. ReentrantLock3. 原子类4. 线程池5. 信号量 Semaphore6. CountDownLatch 1. Callable 接口 Callable Interface 也是一种创建线程的方式 Runnable 能表示一个任务 (run方法) – 返回 voidCallable 也能表示一个任务(call方法) 返回一个具体的…...
java项目运行时信息获取
大体思路如下,想要获取启动时处理器数量、jvm 相关信息,操作系统信息、运行机器信息 运行机器信息 import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.lang.invoke.MethodHandles;/*** 机器工具类*/ public abstract class ServerU…...
【LeetCode】71. 简化路径
1 问题 给你一个字符串 path ,表示指向某一文件或目录的 Unix 风格 绝对路径 (以 / 开头),请你将其转化为更加简洁的规范路径。 在 Unix 风格的文件系统中,一个点(.)表示当前目录本身…...
操作系统【OS】进程的控制【进程的创建、终止、阻塞、唤醒】
定义和过程 对应事件 创建 允许一个进程创建另一个进程允许子进程继承父进程所拥有的资源创建进程的过程如下: 申请一个空白的 PCB,并向 PCB 中填写一些控制和管理进程的信息,比如进程的唯一标识等;为该进程分配运行时所必需的…...
写一个简单的解释器(2) 构建标记流
确定标记类型 分为几个大类: 用户符号(类型/标识符/数字/字符串…)关键字 (流程控制和定义符)括号 (这里暂时认为 [] 属于括号)分号 上述四类标记基本囊括了 vc \texttt{vc} vc 中的所有最小单元的类型,但是因为构…...
Leetcode1833. 雪糕的最大数量
Every day a Leetcode 题目来源:1833. 雪糕的最大数量 解法1:贪心 排序 本题唯一的难点在于计数排序。 计数排序详解:C算法之计数排序 为了尽可能多的买到雪糕,我们选择从价格低的雪糕开始买,统计能够买到的雪糕…...
idea 里 没有svn选项的处理办法
总结一下没有svn选项的几种情况: 情况1:IntelliJ IDEA打开带SVN信息的项目不显示SVN信息,项目右键SVN以及图标还有Changes都不显示解决方法 在VCS菜单中有个开关,叫Enabled Version Control Integration,在打开的窗口…...
基于SpringBoot的招生管理系统
基于SpringBoot的招生管理系统的设计与实现~ 开发语言:Java数据库:MySQL技术:SpringBootMyBatisVue工具:IDEA/Ecilpse、Navicat、Maven 系统展示 主页 登录界面 管理员界面 用户界面 摘要 基于SpringBoot的招生管理系统是一款现…...
01、MySQL-------性能优化
目录 一、影响性能的相关因素存储过程: 二、sql优化1>、Mysql系统架构2>、引擎区别: 3>、索引1、什么是索引?联合主键索引理解:索引长度理解:什么是慢查询? 1)、索引理解2)…...
Flutter - APP跳转高德、百度、腾讯、谷歌地图
demo 地址: https://github.com/iotjin/jh_flutter_demo 代码不定时更新,请前往github查看最新代码 这里介绍的是不需要自己开发地图,直接通过给定的经纬度,跳转到三方地图APP调用导航的方式 一种是写的工具类,一种是通过调用三方…...
日志吞吐暴跌60%?Docker默认json-file驱动正在悄悄拖垮你的K8s集群,立即检查这3个隐藏参数!
第一章:Docker 日志优化Docker 容器默认将应用日志输出到 stdout/stderr,由 Docker daemon 统一捕获并存储为 JSON 文件。随着容器数量和运行时长增加,未经管理的日志会迅速膨胀,占用大量磁盘空间,甚至导致宿主机存储耗…...
胡桃工具箱完整使用指南:从零开始掌握原神最强桌面助手
胡桃工具箱完整使用指南:从零开始掌握原神最强桌面助手 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 🧰 / Multifunctional Open-Source Genshin Impact Toolkit 🧰 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.Hu…...
【独家首发】Docker存储基准测试报告:AWS EBS gp3、Azure Premium SSD、阿里云ESSD三平台在10万小文件IO场景下的真实延迟对比(附压测脚本开源)
第一章:Docker存储架构原理与核心概念Docker 存储架构是容器运行时数据持久化与镜像分层管理的底层基石,其设计围绕**写时复制(Copy-on-Write, CoW)** 机制展开,兼顾性能、隔离性与空间复用。容器启动时并不复制整个镜…...
2025届学术党必备的AI辅助论文神器实际效果
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当下,各种各样的AI生成内容检测器被广泛地运用着,这致使那些依赖AI辅…...
BilibiliDown:免费开源B站视频下载器的终极完整指南
BilibiliDown:免费开源B站视频下载器的终极完整指南 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mirrors/bi/…...
代购系统分账系统设计:平台、代购、物流多方自动分账
代购行业订单链路长、参与方多、结算复杂,人工对账易出错、资金占用高、合规风险大。一套适配平台 代购 物流的自动分账系统,可实现资金合规托管、规则智能计算、订单触发分账、对账一键生成,彻底解决多方结算痛点。 一、核心设计目标 合…...
如何高效管理原神游戏数据:开源工具箱的终极解密
如何高效管理原神游戏数据:开源工具箱的终极解密 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 🧰 / Multifunctional Open-Source Genshin Impact Toolkit 🧰 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.Hutao …...
【限时开源】我司金融级Docker沙箱基线镜像(已通过CNCF Sig-Auth认证,仅开放72小时下载)
第一章:Docker沙箱的核心价值与金融级安全边界在金融行业,容器化运行环境不仅需满足常规隔离性要求,更须承载交易系统、风控引擎与客户数据处理等高敏场景的强合规约束。Docker沙箱通过内核命名空间(Namespaces)、控制…...
如何用Bilibili-Evolved打造终极B站体验:新手完整指南
如何用Bilibili-Evolved打造终极B站体验:新手完整指南 【免费下载链接】Bilibili-Evolved 强大的哔哩哔哩增强脚本 项目地址: https://gitcode.com/gh_mirrors/bi/Bilibili-Evolved Bilibili-Evolved是一款功能强大的哔哩哔哩增强脚本,通过丰富的…...
别再死记硬背了!用动画图解二叉排序树的插入与删除(附C++代码调试技巧)
动画拆解二叉排序树:从插入删除到调试实战 二叉排序树是数据结构中最经典的平衡与搜索思想的结合体,但很多初学者在理解插入和删除操作时,常常陷入机械记忆的困境。本文将通过动画分步演示和IDE调试技巧,带您真正掌握二叉排序树的…...
