LeetCode 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]

提示:

1 <= nums.length <= 50000

-50000 <= nums[i] <= 50000

class Solution {
public:
vector<int> sortArray(vector<int>& nums) {
//bubbleSort(nums); //selectionSort(nums); //InsertionSort(nums); //ShellSort(nums); //return mergeSort(nums); //quickSort(nums,0,nums.size()-1); heapSort(nums); return nums;
} // 冒泡排序 O(n²)
void bubbleSort(vector<int>& nums){
for(int i=nums.size()-1;i>0;i--)
for(int j=0;j<i;j++){
if(nums[j]>nums[j+1])
swap(nums[j],nums[j+1]);
}
} // 选择排序 O(n²)
void selectionSort(vector<int>& nums){
for(int i=nums.size()-1;i>0;i--){
int maxSub=0;
for(int j=1;j<=i;j++){
if(nums[j]>nums[maxSub])
maxSub=j;
}
swap(nums[i],nums[maxSub]);
} } // 插入排序 O(n²)
void InsertionSort(vector<int>& nums){
for(int i=1;i<nums.size();i++){
int pos=i;
int curVal = nums[i];
while(pos>0 && nums[pos-1]>curVal){
nums[pos]=nums[pos-1];
pos--;
}
nums[pos]=curVal;
}
} //希尔排序 O(nlogn)
void ShellSort(vector<int>& nums){
for(int gap = nums.size()/2; gap>0; gap/=2)
for(int i=gap; i<nums.size();i++){
int curVal = nums[i];
int pos=i;
while(pos>=gap && nums[pos-gap]>curVal){
nums[pos]=nums[pos-gap];
pos-=gap;
}
nums[pos]=curVal;
}
} // 归并排序 O(nlogn) 空间上的开销
vector<int> mergeSort(vector<int> nums){
if(nums.size()<2)
return nums; int l=0,r=nums.size()-1;
int mid=(l+r)/2;
vector<int> left = mergeSort(vector<int>(nums.begin(),nums.begin()+mid+1)); //类似数组切片 ,注意mid+1
vector<int> right= mergeSort(vector<int>(nums.begin()+mid+1,nums.end())); int i=0,j=0;
vector<int> res;
while(i<left.size() && j<right.size()){
if(left[i]<right[j]){
res.push_back(left[i]);
i++;
}
else{
res.push_back(right[j]);
j++;
}
} if(i<left.size())
res.insert(res.end(),left.begin()+i,left.end());
else if(j<right.size())
res.insert(res.end(),right.begin()+j,right.end());
return res;
} //归并排序 写法2 temp数组有效利用空间
void mergeSort(vector<int>& nums, vector<int>& temp, int l, int r){
if(r-l<1) return; int mid=(l+r)/2;
mergeSort(nums,temp,l,mid);
mergeSort(nums,temp,mid+1,r); int i=l,k=l,j=mid+1;
while(i<=mid && j<=r)
if(nums[i]<=nums[j]) temp[k++]=nums[i++];
else temp[k++]=nums[j++]; while(i<=mid) temp[k++]=nums[i++];
while(j<=r) temp[k++]=nums[j++];
while(--j>=l) nums[j]=temp[j];
} // 快速排序 O(nlogn)
void quickSort(vector<int>& nums, int l,int r){
if(l>=r)
return; swap(nums[l], nums[rand() % (r - l + 1) + l]); // 不随机会超时
int pivot=nums[l];
int i=l+1, j=r; //注意此处从 l+1 开始算
while(i<=j){ //注意比较符号 <=
while(i<=j && nums[i]<=pivot) i++;
while(i<=j && nums[j]>=pivot)j--;
if(j<i) break;
swap(nums[i],nums[j]);
}
swap(nums[j],nums[l]);
quickSort(nums,l,j-1);
quickSort(nums,j+1,r); } //快速排序 写法2
void quickSort2(vector<int>& nums,int l, int r){
if(l>=r) return; //swap(nums[l],nums[random()%(r-l+1)+l]);
int pivot=nums[l];
int i=l,j=r;
while(i<j){
while(i<j && nums[j]>=pivot)j--;
while(i<j && nums[i]<=pivot)i++;
swap(nums[i],nums[j]);
}
swap(nums[l],nums[i]);
quickSort2(nums,l,i-1);
quickSort2(nums,i+1,r);
}
// 堆排序 O(nlogn)
void heapSort(vector<int>& nums){
int len=nums.size();
for(int i=len/2-1; i>=0;i-- ) //构建大根堆
MaxHeapify(nums, len, i); for(int i=len-1;i>0;i--){
swap(nums[0],nums[i]); // 根(最大值)放在末尾排序部分
MaxHeapify(nums,i, 0); // 调整未排序部分
}
} //堆调整
void MaxHeapify(vector<int>& nums,int len,int index){
int lc=2*index+1;
int rc=2*index+2;
int largest=index; if(lc<len && nums[lc]>nums[largest])
largest=lc;
if(rc<len && nums[rc]>nums[largest])
largest=rc; if(largest!=index){
swap(nums[index],nums[largest]); //交换父子节点的值
MaxHeapify(nums, len, largest); //调整子树
}
} };

【数据结构 C++】排序——冒泡、插入、选择、希尔、归并、快排、堆排序的更多相关文章

  1. c++ 排序 冒泡 插入 选择 快速

    //冒泡 #include <iostream> using namespace std; void bubbleSort(int* list,int index) { ;i--) //i ...

  2. 《java数据结构与算法》系列之“简单排序"-冒泡,选择,插入

    好几天又没写,因为这几天很闲,平时忙的时候自己再累都不会睡着,但是呢这没事了,照理说应该是不瞌睡了,结果还睡着了. 所以说,人很贱.也验证了一句话,没有目标的人其实最无聊.人一定要有自己的工作,这工作 ...

  3. Java数据结构和算法(三)--三大排序--冒泡、选择、插入排序

    三大排序在我们刚开始学习编程的时候就接触过,也是刚开始工作笔试会遇到的,后续也会学习希尔.快速排序,这里顺便复习一下 冒泡排序: 步骤: 1.从首位开始,比较首位和右边的索引 2.如果当前位置比右边的 ...

  4. java面试准备之基础排序——冒泡与选择排序

    选择排序:     [java]    public void select(int[] arr){            for(int i=0;i<arr.length;i++){      ...

  5. (三)Java数据结构和算法——冒泡、选择、插入排序算法

    一.冒泡排序 冒泡算法的运作规律如下: ①.比较相邻的元素.如果第一个比第二个大,就交换他们两个. ②.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.这步做完后,最后的元素会是最大的数( ...

  6. 数据结构65:快速排序算法(QSort,快排)

    上节介绍了如何使用起泡排序的思想对无序表中的记录按照一定的规则进行排序,本节再介绍一种排序算法——快速排序算法(Quick Sort). C语言中自带函数库中就有快速排序——qsort函数 ,包含在 ...

  7. 【PHP数据结构】交换排序:冒泡、快排

    上篇文章中我们好好地学习了一下插入类相关的两个排序,不过,和交换类的排序对比的话,它们真的只是弟弟.甚至可以说,在所有的排序算法中,最出名的两个排序都在今天要介绍的交换排序中了.不管是冒泡.还是快排, ...

  8. 冒泡,快排算法之javascript初体验

    引子:javascript实际使用的排序算法在标准中没有定义,可能是冒泡或快排.不用数组原生的 sort() 方法来实现冒泡和快排. Part 1:冒泡排序(Bubble Sort) 原理:临近的两数 ...

  9. python 冒泡和快排,不多说【无聊】

    #-*-coding:utf8-*- import random a=[] b=[] def init_array(): for i in range(10000): v = random.randi ...

  10. python 冒泡和快排,不多说

    #-*-coding:utf8-*- import random a=[] b=[] def init_array(): for i in range(10000): v = random.randi ...

随机推荐

  1. JDK1.8源码(六)——java.util.ArrayList类

    ArrayList实现了Serializable接口,因此它支持序列化,能够通过序列化传输,实现了RandomAccess接口,支持快速随机访问,实际上就是通过下标序号进行快速访问,实现了Clonea ...

  2. JAVA安全基础之反射

    JAVA安全基础之反射 在JAVA安全中,反射是一个经常使用的技术,所以熟悉使用反射是非常必要的.下面就简单的讲下JAVA的反射的用法 什么是反射 每个类都有对应的Class类对象,该Class类对象 ...

  3. 常用CSS的布局问题;

    一.溢出文案省略号显示: //当文字长度超过50px会已省略好的方式显示: width:50px; overflow: hidden; text-overflow: ellipsis; white-s ...

  4. Docker修改容器中的时间

    Docker修改容器中的时间 前言 在公司开发时使用 Docker 创建数据库(SQL Server)的实例十分方便,还原数据库也只要设置好共享文件夹,在 SQL Server Management ...

  5. 深入浅出 BPF TCP 拥塞算法实现原理

    本文地址:https://www.ebpf.top/post/ebpf_struct_ops 1. 前言 eBPF 的飞轮仍然在快速转动,自从 Linux 内核 5.6 版本支持 eBPF 程序修改 ...

  6. PHP的zlib压缩工具扩展包学习

    总算到了我们压缩相关扩展的最后一篇文章了,最后我们要学习的也是 Linux 下非常常用的一种压缩格式:.gz 的压缩扩展.作为 PHP 的自带扩展,就像 zip 一样,zlib 扩展是随着 PHP 的 ...

  7. Java基础系列(27)- 什么是方法

    何谓方法 System.out.println();它是什么呢 # System:类 # out:对象 # println():方法 Java方法是语句的集合,它们在一起执行一个功能 方法是解决一类问 ...

  8. Postman 如何调试加密接口?

    大家好,我是安果! 众所周知,Postman 是一款非常流行且易用的 API 调试工具,在接口调试或测试时经常被使用针对普通 API 接口,我们可以直接在 Postman 中输入 URL.Query ...

  9. Dubbo 学习(二)服务注册与发现

    在上一篇中我们提到,dubbo官网上推荐使用ZooKeeper作为注册中心.那么今天我们就通过代码来实践一番,看看一个dubbo的服务消费者如果找到通过ZooKeeper暴露自己的dubbo服务提供者 ...

  10. 鸿蒙内核源码分析(任务管理篇) | 任务池是如何管理的 | 百篇博客分析OpenHarmony源码 | v5.05

    百篇博客系列篇.本篇为: v05.xx 鸿蒙内核源码分析(任务管理篇) | 任务池是如何管理的 | 51.c.h .o 任务管理相关篇为: v03.xx 鸿蒙内核源码分析(时钟任务篇) | 触发调度谁 ...