C++排序算法
排序算法复习
冒泡排序
链接:https://www.runoob.com/w3cnote/bubble-sort.html
每次循环对比【相邻】两个元素,将最大的元素放到数组最后
void bubbleSort(int* arr, int n){//每次确认一个元素的最终位置,循环n-1次即可确认全部元素的最终位置//外层只是用来控制循环次数,并没有参与比较for(int i = 0; i < n - 1; i++){//每次确认的元素都会被放在数组最后,所以要循环遍历前面的元素//循环i次时确认了i+1个元素的位置,还剩下n-(i+1)个元素的位置待确认,所以内部循环n-i-1次for(int j = 0; j < n - i - 1; j++){if(arr[j] > arr[j + 1]){ //升序排序,所以用大于号swap(arr[j], arr[j + 1]);}}}
}
选择排序
链接:https://www.runoob.com/w3cnote/selection-sort.html
每次循环对比i和j位置的元素(不一定相邻),不断交换i和j位置的元素,将最小的元素放在最前面
void selectionSort(int* arr, int n){//每次循环确认一个元素的最终位置//升序排序:每次将未确定最终位置的元素中最小的放在最前面for(int i = 0; i < n - 1; i++){//内层循环寻找小于当前i位置元素的最小值for(int j = i + 1; j < n; j++){if(arr[i] > arr[j]){swap(arr[i], arr[j]);}}}
}
插入排序
链接:https://www.runoob.com/w3cnote/insertion-sort.html
每次循环就是将第i+1个元素插入到已经排好序的i个元素中;
对几乎已经排好序的序列进行排列时比较高效。
void insertionSort(int* arr, int n){for(int i = 1; i < n; i++){int tmp = arr[i]; //arr[i]是需要单独记录的,因为随着插入排序的进行,原来i位置的元素会改变int j;for(j = i; j > 0; j--){if(arr[j - 1] > tmp) arr[j] = arr[j - 1];else{break;}}arr[j] = tmp;}
}
希尔排序 / 缩小增量排序
链接:https://www.runoob.com/w3cnote/shell-sort.html
插入排序的升级版,先将整个待排序的序列分割成若干个子序列分别进行直接插入排序,待整个序列中的记录基本有序时,再依次对全体数据进行直接插入排序
void shellSort(int* arr, int n){int h = 1; //增量while(h < n / 3){h = h * 3 + 1;}while(h >= 1){//外层只是用来控制循环次数,没有参与比较for(int i = h; i < n; i++){for(int j = i; j >= h; j -= h){if(arr[j] < arr[j - h]){swap(arr[j], arr[j - h]);}}}h /= 3; //缩小增量}
}
归并排序
链接:https://blog.csdn.net/yang_yi520/article/details/125001902
分治思想,先解决小问题,再解决大问题
void merge(int* arr, int left, int mid, int right, int* temp){int i = left;int j = mid + 1;int cur = 0;while(i <= mid && j <= right){if(arr[i] < arr[j]){temp[cur++] = arr[i++];}else{temp[cur++] = arr[j++];}}while(i <= mid){temp[cur++] = arr[i++];}while(j <= right){temp[cur++] = arr[j++];}int n = right - left + 1;for(int i = 0; i < n; i++){arr[left + i] = temp[i];}
}void mergeSort(int* arr, int left, int right, int* temp){if(left < right){int mid = left + ((right - left) >> 1);mergeSort(arr, left, mid, temp); //先排 left-mid 位置的元素mergeSort(arr, mid + 1, right, temp); //再排 mid+1-right 位置的元素merge(arr, left, mid, right, temp); //将排好序的两边归并}
}
快速排序
链接:https://blog.csdn.net/weixin_45031801/article/details/126962679
分治,先解决大问题,再解决小问题
int part(int* arr, int left, int right){int pivot = arr[left];int i = left;int j = right;while(i < j){while(i < j && arr[j] > pivot){j--;}if(i < j) swap(arr[i++], arr[j]);while(i < j && arr[i] < pivot){i++;}if(i < j) swap(arr[i], arr[j--]);}return i;
}void quickSort(int* arr, int left, int right){if(left < right){int mid = part(arr, left, right);quickSort(arr, left, mid - 1); //mid-1quickSort(arr, mid + 1, right); //mid+1}
}
堆排序
视频教程
//堆是一个完全二叉树//n: 堆中元素数量
//i: 要维护的元素
void heapify(int* arr, int n, int i) {int largest = i; //先假定当前父子节点三个元素中最大值在父节点所在位置int lson = i * 2 + 1; //左孩子下标int rson = i * 2 + 2; //右孩子下标//要记得判断孩子下标是否超出范围if (lson < n && arr[largest] < arr[lson])largest = lson;if (rson < n && arr[largest] < arr[rson])largest = rson;if (largest != i) {swap(arr[largest], arr[i]);heapify(arr, n, largest); //交换完元素后要继续维持堆的秩序}
}void heapSort(int* arr, int n) {//建堆//n/2-1 是堆中最后一个拥有子节点的父节点的下标for (int i = n / 2 - 1; i >= 0; i--) {heapify(arr, n, i);}//排序for (int i = n - 1; i > 0; i--) {swap(arr[i], arr[0]); //将堆中最大的元素放到最后heapify(arr, i, 0); //确定最大元素的位置后,剩余i个元素,从位置0开始维持堆的秩序}
}
计数排序
视频教程
//计数排序只能用于正数排序
void countSort(int* arr, int n) {//找到最大值以构造累计数组int max = 0;for (int i = 0; i < n; i++) {max = max > arr[i] ? max : arr[i];}//构造累计数组vector<int> count(max + 1, 0); //计数数组for (int i = 0; i < n; i++) {count[arr[i]]++;}//将计数数组转为累计数组for (int i = 1; i < count.size(); i++) {count[i] += count[i - 1];}//计算最终排序vector<int> temp(n, 0);for (int i = 0; i < n; i++) {int index = count[arr[i]] - 1;temp[index] = arr[i];count[arr[i]]--;}for (int i = 0; i < n; i++) {arr[i] = temp[i];}
}
桶排序
链接:https://zhuanlan.zhihu.com/p/164992268
void bucketSort(int* arr, int n) {vector<vector<int>> bucket(5, vector<int>());for (int i = 0; i < n; i++) {bucket[arr[i] / 5].push_back(arr[i]);}for (int i = 0; i < 5; i++) {sort(bucket[i].begin(), bucket[i].end());}int cur = 0;for (int i = 0; i < 5; i++) {for (int j = 0; j < bucket[i].size(); j++) {arr[cur++] = bucket[i][j];}}
}
基数排序
视频教程
void radixSort(int* arr, int n, int digit) {vector<int> record(n);vector<int> count(10);for (int i = 0; i < digit; i++) {int division = pow(10, i);for (int j = 0; j < n; j++) {int num = arr[j] / division % 10;count[num]++;}for (int j = 1; j < 10; j++) {count[j] += count[j - 1];}for (int j = n - 1; j >= 0; j--) {int num = arr[j] / division % 10;record[--count[num]] = arr[j];}for (int j = 0; j < n; j++) {arr[j] = record[j];}count.assign(10, 0);}
}int main() {int arr[10] = { 223, 124, 90, 8, 1128, 67, 980, 123, 90, 78 };int digit = 0;//确定变量中最大位数for (int i = 0; i < 10; i++) {int count = 0;int tmp = arr[i];while (tmp) {tmp /= 10;count++;}digit = digit > count ? digit : count;}radixSort(arr, 10, digit);for (int i = 0; i < 10; i++) {cout << arr[i] << " ";}cout << endl;
}
相关文章:
C++排序算法
排序算法复习 冒泡排序 链接:https://www.runoob.com/w3cnote/bubble-sort.html 每次循环对比【相邻】两个元素,将最大的元素放到数组最后 void bubbleSort(int* arr, int n){//每次确认一个元素的最终位置,循环n-1次即可确认全部元素的最…...
JAVA后端部署项目三步走
1. JAVA部署项目三步走 1.1 查看 运行的端口 lsof -i:8804 (8804 为端口) 发现端口25111被监听 1.2 杀死进程,终止程序 pid 为进程号 kill -9 pid 1.3 后台运行jar包 nohup java -jar -Xms128M -Xmx256M -XX:MetaspaceSize128M -XX:MaxM…...
php使用zookeeper实现分布式锁
介绍 一、zookeeper和redis实现分布式锁的对比 1、redis 分布式场景应用比较广泛,redis分布式锁,其实需要自己不断去尝试获取锁,比较消耗性能;zk分布式锁,获取不到锁,注册个监听器即可,不需要不…...
力扣-可回收且低脂的产品
大家好,我是空空star,本篇带大家了解一道超级超级超级简单的力扣sql练习题。 文章目录前言一、题目:1757. 可回收且低脂的产品二、解题1.正确示范①提交SQL运行结果2.正确示范②提交SQL运行结果3.正确示范③提交SQL运行结果4.正确示范④提交S…...
代码随想录刷题-数组-二分查找
文章目录写在前面原理习题题目1思路和代码题目-2写在前面 这个专栏是记录我刷代码随想录过程中的随想和总结。每一小节都是根据自己的理解撰写的,文章比较短,主要是为了记录和督促自己。刷完一章后,我会再单独整理一篇文章来总结和分享。 本…...
HCIA复习1
HCIA复习 抽象语言---->编码 编码---->二进制 二进制--->电信号 处理电信号 OSI参考模型----OSI/RM 应用层 表示层 会话层 传输层 端口号:0-65535;1-1023是注明端口 网络层 IP地址 数据链路层 物理层 ARP协议 正向ARP---通过IP地址获取目的MAC地…...
Kotlin中的destructuring解构声明
开发中有时只是想分解一个包含多个字段的对象来初始化几个单独的变量。要实现这一点,可以使用Kotlin的解构声明。本文主要了解:“1、如何使用解构声明这种特性 2、底层是如何实现的 3、如何在你自己的类中实现它1、解构声明的使用解构声明&a…...
Kubernetes Pod 水平自动伸缩(HPA)
Pod 自动扩缩容 之前提到过通过手工执行kubectl scale命令和在Dashboard上操作可以实现Pod的扩缩容,但是这样毕竟需要每次去手工操作一次,而且指不定什么时候业务请求量就很大了,所以如果不能做到自动化的去扩缩容的话,这也是一个…...
钉钉、企业微信和飞书向“钱”看
在急剧变革的时候,不管黑猫白猫,要抓到老鼠才算好猫。如今,各互联网企业早已进入降本增效的新阶段。勒紧裤腰带过日子之下,能不能盈利、商业化空间有多大,就成为各个业务极为重要的考核指标。在各业务板块中࿰…...
网上购物网站的设计
技术:Java、JSP等摘要:本文介绍了JSP和JAVA等相关技术,针对网上购物系统的实际需求,设计开发了一个基于JSP的小型电子商务网站也就是网上购物系统,。在设计开发中,采用的是SSH框架(strutsspring…...
【Java学习笔记】8.Java 运算符
Java 运算符 计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量。我们可以把运算符分成以下几组: 算术运算符关系运算符位运算符逻辑运算符赋值运算符其他运算符 算术运算符 算术运算符…...
RHCSA-使用命令管理文件(3.6)
硬链接与软链接基本操作: 创建软硬连接的命令:ln 硬链接:ln 源文件(已经存在的文件) 链接文件名(新建) 软连接:ln -s 源文件(已存在的文件) 快捷方式文件名…...
socket聊天室--socket的建立
socket聊天室–socket实现 文章目录 socket聊天室--socket实现socket()bind()listen()accept()connect()发送接收read()函数recv()函数write()函数send()函数close()关闭套接字IP 地址格式转换函数socket() #include <sys/types...
Raft图文详解
Raft图文详解 refer to: Raft lecture (Raft user study) - YouTube Raft PDF Raft算法详解 - 知乎 (zhihu.com) 今天来详细介绍一下Raft协议 Raft是来解决公式问题的协议,那么什么是共识呢? 在分布式系统里面,consensus指的是多个节点对…...
春季出游,学会这些功能,让你旅途更舒心
春意盎然,万物复苏,春天正是旅游观光的好时节,相信不少小伙伴已经做好了出游的准备。想拥有好的心情,除了美食美景,好的出游神器也必不可少,好的出游神器能让我们的旅途更舒心,一起来看看是哪些…...
【华为OD机试真题java、python、c++、jsNode】简单的自动曝光【2022 Q4 100分】(100%通过)
代码请进行一定修改后使用,本代码保证100%通过率。本文章提供java、python、c++、jsNode四种代码 题目描述 一个图像有n个像素点,存储在一个长度为n的数组img里,每个像素点的取值范围[0,255]的正整数。 请你给图像每个像素点值加上一个整数k(可以是负数),得到新图newImg…...
react学习笔记-1:创建项目
安装nodejs https://nodejs.org/dist/v18.14.2/node-v18.14.2-x64.msi 修改国内源:npm config set registry https://registry.npm.taobao.org 使用create-react-app脚手架创建项目 安装脚手架 npm install -g create-react-app 全局安装,可以在任意的…...
vulnhub five86-2
总结:sudo -l,抓流量包,搜索引擎。。 目录 下载地址 漏洞分析 信息收集 网站渗透 编辑 反弹shell提权 下载地址 Five86-2.zip (Size: 1.7 GB)Download (Mirror): https://download.vulnhub.com/five86/Five86-2.zip使用:下…...
OpenCV入门(四)快速学会OpenCV3画基本图形
OpenCV入门(四)快速学会OpenCV3画基本图形 1.画点 在OpenCV中,点分为2D平面中的点和3D平面中的点,区别就是3D中点多了一个z坐标。我们首先介绍2D中的点,坐标为整数的点可以直接用(x, y)代替,其中x是横坐标…...
【MAC OS 命令行】Redis的安装、启动和停止。就是如此简单
目录Mac 安装 Redis使用 Homebrew 安装 Redis总结Mac 安装 Redis 使用 Homebrew 安装 Redis 如果没有安装 Homebrew,先安装 Homebrew 执行命令: 方法一、brew 官网的安装脚本 /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homeb…...
java毕业设计基于springboot+vue的滑雪场雪具租赁服务系统
前言 随着滑雪运动的普及和滑雪场规模的扩大,滑雪场对雪具租赁服务的需求日益增加。传统的租赁方式存在管理效率低下、用户体验不佳等问题,无法满足现代滑雪场的需求。因此,开发一个基于Spring Boot的滑雪场雪具租赁服务系统,旨在…...
生物信息学新手必看:BBmap比对工具从安装到实战全流程指南
生物信息学新手必看:BBmap比对工具从安装到实战全流程指南 第一次接触生物信息学数据分析时,面对海量的测序数据往往会感到无从下手。比对工具的选择尤为关键——既要保证准确性,又要兼顾效率。BBmap作为BBTools套件中的核心工具,…...
PyTorch模型性能分析与瓶颈定位:使用PyTorch Profiler工具详解
PyTorch模型性能分析与瓶颈定位:使用PyTorch Profiler工具详解 1. 为什么需要性能分析工具 训练深度学习模型时,我们经常会遇到这样的困惑:为什么模型训练这么慢?是数据加载拖慢了速度,还是计算本身效率低下…...
终极GitHub加速解决方案:让你的代码下载速度提升100倍
终极GitHub加速解决方案:让你的代码下载速度提升100倍 【免费下载链接】Fast-GitHub 国内Github下载很慢,用上了这个插件后,下载速度嗖嗖嗖的~! 项目地址: https://gitcode.com/gh_mirrors/fa/Fast-GitHub 你是否曾经因为G…...
DownKyi:3分钟掌握B站视频下载的高效方法
DownKyi:3分钟掌握B站视频下载的高效方法 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等)。 项…...
新手必看:5分钟学会用Visio绘制PAD图和N-S图(附实例解析)
零基础掌握Visio绘制PAD图与N-S图的实战指南 在软件设计领域,可视化工具的重要性不言而喻。对于刚入门的开发者来说,掌握如何将抽象的逻辑思维转化为直观的图表是一项必备技能。Visio作为微软旗下的专业绘图工具,以其友好的界面和强大的功能&…...
FPGA时序路径实战解析:从理论到约束的四大关键场景
1. 时序路径基础:FPGA设计的生命线 第一次接触FPGA时序约束时,我盯着时序报告里密密麻麻的路径延迟数据发懵——这些红色警告就像交通信号灯,而我完全看不懂它们的规则。直到真正理解了时序路径这个概念,才明白它其实就是FPGA设计…...
快马AI一键生成链表可视化原型,交互演示助力算法设计
最近在复习数据结构时,发现链表这种基础但重要的结构,光看静态图示很难理解指针变化。正好尝试用InsCode(快马)平台快速搭建了一个可视化演示工具,整个过程比想象中简单很多,分享下实现思路: 需求拆解 首先明确需要实现…...
zynq ebaz4205开发板附带数字识别fpga例程 搭配ov7670/ov7725双目h...
zynq ebaz4205附带数字识别fpga例程代码 )扩展板zynq摄像头采集hdmi显示zynq ebaz4205 手机充电线micro usb供电,包含ov双目hdmi扩展板、配有micro usb供电、摄像头手机充电器一般即可充电,使用ov7670或原子ov7725摄像头,需要部分…...
路径遍历 PortSwigger labs
File path traversal, simple case 实验信息 平台:PortSwigger Web Security Academy 漏洞:路径遍历漏洞(Path Traversal) Lab:Server-side vulnerabilities - PortSwigger 难度:简单 漏洞原理 网站通过 filena…...
