排序算法——梳理总结

✨冒泡
✨选择
✨插入
 ✨标准写法
 🎭不同写法
✨希尔排序——标准写法
✨快排
✨归并
✨堆排

在这里插入图片描述

冒泡

在这里插入图片描述

void Bubble(vector<int>& nums)
{// 冒泡排序只能先确定最右边的结果,不能先确定最左边的结果for (int i = 0; i < nums.size(); i++){// 确定的右边的就不用排了并且不能让j+1越界// 所以判断条件是nums.size()-i - 1for (int j = 0; j < nums.size()-i - 1; j++)if (nums[j] > nums[j + 1])swap(nums[j], nums[j + 1]);}
}

选择

选择排序重要的是选,先选出来,再将这个数交换进去
在这里插入图片描述

void Select(vector<int>& nums)
{for (int i = 0; i < nums.size(); i++){int t = i;// 记录需要交换的数的位置for (int j = i + 1; j < nums.size(); j++)if (nums[t] > nums[j])t = j;swap(nums[t], nums[i]);}
}

插入

在这里插入图片描述

标准写法

插入排序是一个一个往后挪,最后再插入

void Insert(vector<int>& nums)
{for (int i = 0; i < nums.size(); i++){int t = nums[i];// 注意j表示需要检查的位置,这个位置必须遵循j>=0for (int j =i-1; j >= 0; j--){if (nums[j] > t)nums[j + 1] = nums[j];else{nums[j + 1] = t;break;}}}
}

注意j的范围

🎭不同写法

这种写法类似于冒泡排序,他是往前冒,虽然能对,但是这已经不是插入排序的思想

int* sortArray(int* nums, int numsSize, int* returnSize)
{//插入排序:在已经排好序的数组中进行插入*returnSize=numsSize;for(int i=0;i<numsSize;i++){//从此位置向前比for(int j=i;j>0;j--){if(nums[j]<nums[j-1]){int tem=nums[j];nums[j]=nums[j-1];nums[j-1]=tem;}elsebreak;}}return nums;
}

希尔——标准写法

在这里插入图片描述

希尔排序是在插入排序的基础上发展而来,所以要遵循插入排序的逻辑
他和插入排序不同在于,插入排序的gap=1,这个gap是从大到小变化

void Shell(vector<int>& nums)
{for (int gap = nums.size()/2; gap >0; gap/=2)// 间隔	{//每次向后跳间隔个长度for (int i = 0; i < nums.size(); i++) {int t = nums[i];// 注意j的范围for (int j = i-gap; j >= 0; j -= gap){if (nums[j] > t)nums[j + gap] = nums[j];else{nums[j + gap] = t;break;}}}}
}

注意j的范围


快排

我们使用三段式进行排序
[l,left] [left+1,right-1] [right,r]
[l,left]——小于key
[left + 1 , right-1]—— 等于key,等于key的是不用排序
[right , r]——大于key

int getNum(vector<int>& nums, int l, int r)
{srand(time(nullptr));return nums[l + rand() % (r - l + 1)];
}
void quicksort(vector<int>& nums, int l, int r)
{if (l >= r) return;int key = getNum(nums, l, r);int left = l - 1, right = r + 1, g = l;// 采用三段式进行while (g < right){if (nums[g] == key) g++;else if (nums[g] < key) swap(nums[g++], nums[++left]);else swap(nums[g], nums[--right]);}// [l,left][left+1,right-1][right,r]quicksort(nums, l, left), quicksort(nums, right, r);
}

归并

归并排序需要一个辅助数组,我们使用的是vector,使用之前需要进行resize,开足够大的空间的同时要运行进行随机访问

vector<int> tem;
void mergesort(vector<int>& nums, int l, int r)
{if (l >= r) return;int mid = l + r >> 1;mergesort(nums, l, mid), mergesort(nums, mid + 1, r);int left = l, right = mid + 1;int t = 0;while (left <= mid && right <= r){if (nums[left] < nums[right]) tem[t++] = nums[left++];else tem[t++] = nums[right++];}while (left <= mid) tem[t++] = nums[left++];while (right <= r) tem[t++] = nums[right++];t = 0;left = l;while (left <= r) nums[left++] = tem[t++];
}

堆排

void up(vector<int>& nums,int t)
{while (t > 0){int parent = (t - 1) / 2;// 大根堆if (nums[parent] < nums[t])swap(nums[parent], nums[t]);t = parent;}
}
void down(vector<int>& nums,int t)
{// 需要从这个位置开始向下down到底int child = t * 2 + 1;while (child < nums.size()){// 找到左右孩子中最小的位置//if (child + 1 < nums.size() && nums[child] > nums[child + 1])//	child++;//if(nums[t]>nums[child]) //	swap(nums[t], nums[child]);if (child + 1 < nums.size() && nums[child] < nums[child + 1]) child++;if (nums[t] < nums[child])swap(nums[t], nums[child]);t = child;child = t * 2 + 1;}
}
void Heap(vector<int>& nums)
{//筛选法建立初始堆——小大根堆都可以//for (int i = nums.size()/2; i >= 0; i--) down(nums, i);//for (int i = 0 ; i < nums.size(); i++) up(nums, i);// 如果想用up初始化堆,只能从头开始
}
  1. 筛选法建堆——先将所有数据加入构成堆,在从中间位置开始进行down(只能down,不论是建大堆还是小堆)
    什么时候使用up,为什么up不能在筛选法建堆中使用
    请添加图片描述
    就像上图中的情况,在建小堆的过程中,2是一定不能访问到的,就不能建成小堆,所以不能在筛选法中使用up(关键是筛选法起点是中间位置)
    如果想使用up,必须将每一个进行up,或者是某个位置上面的已经成堆,那么就可以在这个位置直接使用up
    对于down来说,如果某个位置下面已经成堆,那么就可以直接使用down

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/728697.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于深度学习的交通标志检测识别系统(含UI界面、yolov8、Python代码、数据集)

项目介绍 项目中所用到的算法模型和数据集等信息如下&#xff1a; 算法模型&#xff1a;     yolov8 yolov8主要包含以下几种创新&#xff1a;         1. 添加注意力机制&#xff08;SE、CBAM等&#xff09;         2. 修改可变形卷积&#xff08;DySnake-主干c…

linux系统命令深入研究1——ls的参数

ls list命令有一些常用的参数&#xff0c;其中-a意为列出all全部文件&#xff08;包括隐藏文件&#xff09;&#xff0c;-l列出详细信息&#xff0c;-h以人类可阅读的方式列出文件大小 --full-time是列出详细时间信息&#xff0c;包括最后一次修改时间 -t是按时间排序&#xff…

Git 内幕探索:从底层文件系统到历史编辑的全面指南

微信搜索“好朋友乐平”关注公众号。 1. Git 底层文件对象 #mermaid-svg-uTkvyr26fNmajZ3n {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-uTkvyr26fNmajZ3n .error-icon{fill:#552222;}#mermaid-svg-uTkvyr26fNmaj…

Spark实战-基于Spark日志清洗与数据统计以及Zeppelin使用

Saprk-日志实战 一、用户行为日志 1.概念 用户每次访问网站时所有的行为日志(访问、浏览、搜索、点击)用户行为轨迹&#xff0c;流量日志2.原因 分析日志&#xff1a;网站页面访问量网站的粘性推荐3.生产渠道 (1)Nginx(2)Ajax4.日志内容 日志数据内容&#xff1a;1.访问的…

【动态规划】完全背包

欢迎来到Cefler的博客&#x1f601; &#x1f54c;博客主页&#xff1a;折纸花满衣 &#x1f3e0;个人专栏&#xff1a;题目解析 &#x1f30e;推荐文章&#xff1a;【LeetCode】winter vacation training 目录 &#x1f449;&#x1f3fb;完全背包 &#x1f449;&#x1f3fb;…

政安晨:【深度学习处理实践】(二)—— 最大汇聚运算

最大汇聚运算&#xff08;Max Pooling Operation&#xff09;是深度学习领域卷积神经网络常用的一种汇聚运算方式。在卷积神经网络中&#xff0c;经过一系列卷积层和激活函数层后&#xff0c;数据在空间尺寸上逐渐减小&#xff0c;特征图的深度也逐渐增加。为了降低数据尺寸并提…

微信小程序(五十三)修改用户头像与昵称

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.外界面个人资料基本模块 2.资料修改界面同步问题实现&#xff08;细节挺多&#xff0c;考虑了后期转服务器端的方便之处&#xff09; 源码&#xff1a; app.json {"window": {},"usingCompone…

算法打卡day11|栈与队列篇03|Leetcode 239. 滑动窗口最大值、347.前 K 个高频元素

小顶堆和大顶堆 小顶堆&#xff08;Min Heap&#xff09;和大顶堆&#xff08;Max Heap&#xff09;是两种特殊的完全二叉树&#xff0c;它们遵循特定的堆属性&#xff0c;即父节点的值总是小于或等于&#xff08;小顶堆&#xff09;或者大于或等于&#xff08;大顶堆&#xf…

Latex公式太长换行标号

Latex中公式太长换行&#xff0c;且编号&#xff0c;可以采用align&#xff0c;不编号行公式用\nonumber&#xff0c;示例如下&#xff1a; \begin{align}\nonumber %第1行公式不编号&abababababababa\\&cdm %第2行公式编号 \end{align}效果如下 原文件链接 公式不…

WordPress建站入门教程:如何上传安装WordPress主题?

我们成功搭建WordPress网站后&#xff0c;默认使用的是自带的最新主题&#xff0c;但是这个是国外主题&#xff0c;可能会引用一些国外的资源文件&#xff0c;所以为了让我们的WordPress网站访问速度更快&#xff0c;强烈建议大家使用国产优秀的WordPress主题。 今天boke112百…

【MySQL 系列】MySQL 架构篇

在我们开始了解 MySQL 核心功能之前&#xff0c;首先我们需要站在一个全局的视角&#xff0c;来看 SQL 是如何运作执行的。通过这种方式&#xff0c;我们可以在头脑中构建出一幅 MySQL 各组件之间的协同工作方式&#xff0c;有助于我们加深对 MySQL 服务器的理解。 文章目录 1、…

深入浅出运维可观测工具(四):如何使用eBPF绘制网络拓扑图

哈喽~又到了我们技术分享环节了。eBPF这个系列自分享以来收到了很多朋友的喜欢&#xff0c;真是让博主又惊又喜&#xff0c;感谢大家的支持。话不多说&#xff0c;今天我们将对如何使用eBPF绘制网络拓扑图做一篇分享&#xff0c;文章较长&#xff0c;干货较多&#xff0c;大家可…

R语言lavaan结构方程模型在复杂网络分析中的科研技术新趋势

此外&#xff0c;我们还将深入探讨R语言的基础知识、结构方程模型的基本原理、lavaan程序包的使用方法等内容。无论是潜变量分析、复合变量分析&#xff0c;还是非线性/非正态/缺失数据处理、分类变量分析、分组数据处理等复杂问题&#xff0c;我们都将一一为您解析。 希望通过…

微服务获取登录用户Id与单体服务下获取用户Id对比(黑马头条Day03)

前置声明 当前前后端分离开发项目中&#xff0c;后端某个请求向具体某个数据库中的多个表插入数据时&#xff0c;经常需要使用到当前登录用户的Id&#xff08;唯一标识&#xff09;。在当前用户线程下以实现变量共享&#xff0c;同时为了避免不同用户线程之间操作变量的影响&am…

【机器学习300问】28、什么是决策树?

〇、两个预测任务 &#xff08;1&#xff09;任务一&#xff1a;银行预测偿还能力 当前&#xff0c;某银行正致力于发掘潜在的放贷用户。他们掌握了每位用户的三个关键特征&#xff1a;房产状况、婚姻状况以及年收入。此外&#xff0c;银行还拥有过往这些用户的债务偿还能力的…

蓝桥杯简单题,公司名称

题目链接&#xff08;需要登录&#xff09; #include <iostream> #include <cstring> #include <algorithm> using namespace std; bool lanqiao(string str,int len){ sort(str.begin(),str.end());//对str按照ascii排序if(str.find("Laainoq")s…

React 从0到1构建企业级框架基于Antd Designer

一、 create-react-app 创建 cms-front 二、 删除不必须要的文件形成如下结构 1. React版本为17版本 public 文件夹下保留 favicon.ico 偏爱图标index.html资源文件 2.src 保留 index.js 入口文件和app.js(基于spa原则)单文件即可 三、配置eslint 1. 安装 eslint. npm inst…

DataX及使用

DataX及使用 【一】DataX概述【二】DataX架构原理【1】设计理念【2】框架设计【3】运行流程【4】调度决策思路【5】DataX和Sqoop对比 【三】DataX部署【四】DataX上手【1】使用概述【2】配置文件格式【3】同步Mysql数据到HDFS 【五】DataX整合Springboot 【一】DataX概述 Data…

27.基于springboot + vue实现的前后端分离-网上租赁交易系统(项目 + 论文)

项目介绍 本课题是根据用户的需要以及网络的优势建立的一个基于Spring Boot的网上租贸系统&#xff0c;来满足用户网络商品租赁的需求。本网上租贸系统应用Java技术&#xff0c;MYSQL数据库存储数据&#xff0c;基于Spring Boot框架开发。在网站的整个开发过程中&#xff0c;首…

24 Linux PWM 驱动

一、PWM 驱动简介 其实在 stm32 中我们就学过了 PWM&#xff0c;这里就是再复习一下。PWM&#xff08;Pulse Width Modulation&#xff09;&#xff0c;称为脉宽调制&#xff0c;PWM 信号图如下&#xff1a; PWM 最关键的两个参数&#xff1a;频率和占空比。 频率是指单位时间内…