当前位置: 首页 > news >正文

八大排序算法

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1e5+10;
int q[N];
int w[N],s[N];
int n,sz;
//直接插入排序 ,对于某一个元素加入到一个有序的序列中,将该元素依次从该位置开始
//从后往前比较,
//大于该元素的都往后挪一位,直到找到比他小的元素,将该元素插入到比他小的元素的后面。
//
void insert_sort(){for(int i=0;i<n;i++){   // 这里i=1 开始也对int t=q[i],j=i;while(j>0&&q[j-1]>t){swap(q[j],q[j-1]);  // 这里写成q[j]=q[j-1] 也对j--;}q[j]=t;}
}
//折半插入排序 就是在排序的基础上进行二分优化,就是在“将该元素依次从后往前比较”
//这一步中 直接通过二分找到比他小的最大元素 
void binary_search_insert_sort(){for(int i=0;i<n;i++){int t=q[i];if(t>=q[i-1]){q[i]=t;continue;}int l=0,r=i;while(l<r){int mid=l+r>>1;if(q[mid]>t) r=mid;else l=mid+1;}for(int j=i-1;j>=r;j--){q[j+1]=q[j];}q[r]=t;}
}
//冒泡排序  a,b,c,d 从后往前依次做 if c > d 交换二者位置,这样每遍历一次,可以将
//第 i 小的数 放在第i个位置 一共只需要做n-1次。
//y总写的这个是把小的往前冒
//也可以把大的往后冒
void bubble_sort(){for(int i=0;i<n-1;i++){bool has_swap=false;//小优化  如果说当前遍历的过程中,没发生一次交换,说明//当前序列已经是有序的了 可以直接breakfor(int j=n-1;j>i;j--){if(q[j]<q[j-1]) {swap(q[j],q[j-1]);has_swap=true;}}if(!has_swap) break;}
}
//最简单的一集,依次从前往后遍历,每次把后面的最小的一个选出来 放到当前位置。
//总共需要遍历n-1次,因为最后一个位置肯定是符合有序的
void select_sort(){for(int i=0;i<n-1;i++){int k=i;for(int j=i+1;j<n;j++){if(q[j]<q[k]){k=j;}}swap(q[k],q[i]);}
}
//希尔排序:分组+插入排序
void shell_sort(){for(int d=n/3;d;d = d == 2 ? 1 : d / 3){  // 因为希尔排序最后要求公差必须是1//但你每次除三到最后不一定是1 可能是2  2的话我们令公差为1for(int start=0;start<d;start++){for(int i=start+d;i<n;i+=d){int t=q[i],j=i;while(j>start&&t<q[j-d]){swap(q[j],q[j-d]);j=j-d;}q[j]=t;}}}
}
//具体理解 可以参考B站动画演示
void quick_sort(int l,int r){if(l>=r) return;int i=l-1,j=r+1,x=q[(l+r)>>1];while(i<j){do i++;while(q[i]<x);do j--;while(q[j]>x);if(i<j) swap(q[i],q[j]);}quick_sort(l,j);quick_sort(j+1,r);
}
//堆排序要从下标1开始,具体过程可以参考B站动画演示
void down(int t){int u=t;if(u*2<=sz&&q[u*2]>q[t]) t=u*2;if(u*2+1<=sz&&q[u*2+1]>q[t]) t=u*2+1;if(u!=t){ //如果t不是叶子结点 且与儿子结点发生了交换 那么需要递归重新构建儿子的大根堆swap(q[u],q[t]);down(t);//重新构建叶子节点大根堆}
}
void heap_sort(){sz=n;for (int i = n / 2; i; i -- ) down(i);//从最大的非叶子结点开始 将原数组变为一个大根堆for(int i=0;i<n-1;i++){swap(q[1], q[sz]);  // 将堆顶与堆低元素互换 sz -- ;//并且删除堆低元素down(1);//因为发生了交换 破坏了原有的大根堆 需要重新构造大根堆}
}
//归并排序
void merge_sort(int l,int r){if(l>=r) return;int mid=l+r>>1;merge_sort(l,mid),merge_sort(mid+1,r);int i=l,j=mid+1,k=0;while(i<=mid&&j<=r){if(q[i]<=q[j]) w[k++]=q[i++];else w[k++]=q[j++];}while(i<=mid) w[k++]=q[i++];while(j<=r) w[k++]=q[j++];for(i=l,j=0;i<=r;i++,j++) q[i]=w[j];
}
void bucket_sort(){for(int i=0;i<n;i++) s[q[i]]++;for(int i=1;i<N;i++) s[i]=s[i]+s[i-1];for(int i=n-1;i>=0;i--) w[--s[q[i]]]= q[i];// 举个例子  5 3 4 1 1 //s[1]=2  则w[--2]=1  也即w[1]=1 第1个位置应该放后一个1 //s[1]=1  则w[--1]=1  也即w[0]=1 第0个位置应该放前一个1 (先后顺序未发生改变稳定!)//s[4]=4  则w[--4]=4  也即w[3]=4 第三个位置应该放4//s[3]=3  则w[--3]=3  也即w[2]=3 第二个位置应该放3//s[5]=5  则w[--5]=5  也即w[4]=5 第四个位置应该放5//倒着排序可以保证稳定性for(int i=0;i<n;i++) q[i]=w[i];
}
int main(){cin >> n;for(int i=0;i<n;i++){cin >> q[i];}//insert_sort();//binary_search_insert_sort();//bubble_sort();//select_sort();//shell_sort();//quick_sort(0,n-1);//heap_sort();//merge_sort(0,n-1);bucket_sort();for(int i=0;i<n;i++){cout << q[i] << " ";}return 0;
}

相关文章:

八大排序算法

#include<iostream> #include<cstring> #include<algorithm> using namespace std; const int N1e510; int q[N]; int w[N],s[N]; int n,sz; //直接插入排序 ,对于某一个元素加入到一个有序的序列中&#xff0c;将该元素依次从该位置开始 //从后往前比较&…...

机器学习笔记 - 两个静态手势识别的简单示例

一、关于手势识别 手势识别方法通常分为两类:静态或动态。 静态手势是那些只需要在分类器的输入处处理单个图像的手势,这种方法的优点是计算成本较低。动态手势需要处理图像序列和更复杂的手势识别方法。 进一步了解可以参考下面链接。 静态手势识别和动态手势识别的区别和技…...

2023年,有哪些好用的互联网项目管理软件?

项目管理是为了使工作项目能够按照预定的需求、成本、进度、质量顺利完成&#xff0c;而对人员、产品、过程和项目进行分析和管理的活动。 一直以来&#xff0c;项目管理被企业管理人员和各级人员所重视&#xff0c;项目管理是一个项目的灵魂&#xff0c;只有做好了项目管理&am…...

python 按照文件大小读取文件

返回一个list&#xff0c;每个list里面是一个元组(filename, file_size)&#xff0c;按照file_size从小到大排序的 import osdef get_sorted_files(dir_path):# 存储最后的文件路径files []# 便利dir_path下面的文件或者文件夹for file in os.listdir(dir_path):file_path o…...

黑客帝国代码雨

黑客帝国代码雨奉上,之前一直想写,但一直没抽出时间来,今天把他写了,也算了了装心事 效果图如下 原理就不讲了,代码写的很清楚而且不长 有不懂的评论区问我就好 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8">&l…...

基于SpringBoot的植物健康系统

目录 前言 一、技术栈 二、系统功能介绍 系统首页 咨询专家 普通植物检查登记 珍贵植物检查登记 植物救治用料登记 植物救治材料管理 植物疾病案例管理 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 随着信息技术在管理上越来越深入而广泛的应用&am…...

Kettle连接数据库[MySQL]报错

在连接数据库页面填写完成后点击“测试” 报错信息&#xff1a; 错误连接数据库 [ETLqiangzi] : org.pentaho.di.core.exception.KettleDatabaseException: Error occurred while trying to connect to the databaseDriver class org.gjt.mm.mysql.Driver could not be found…...

Postman接口测试学习之常用断言

什么是断言&#xff1f; 断言——就是结果中的特定属性或值与预期做对比&#xff0c;如果一致&#xff0c;则用例通过&#xff0c;如果不一致&#xff0c;断言失败&#xff0c;用例失败。断言&#xff0c;是一个完整测试用例所不可或缺的一部分&#xff0c;没有断言的测试用例…...

自动化机器学习AutoML之flaml:利用flaml框架自动寻找最优算法及其对应最佳参数python

AutoML 一、自动化机器学习包简介1、H2O (Python,R,Java,Scala)2、auto-sklearn(Linux,Python)3、FLAML(Python)4、AutoGlueon(安装比较啰嗦,略过)二、FLAML1、安装2、方法.fit()常用参数介绍3、代码(1) 解决分类问题(2)解决回归问题一、自动化机器学习包简介 机…...

支付宝sdk商户私钥 如何生成?

1、先下载密钥工具 https://opendocs.alipay.com/isv/02kipk 2、安装后生成密钥 3、配置密钥 4、将工具生成的公钥复制进去生成公钥 简单来说就是私钥是用工具生成的&#xff0c;不会在页面上显示 商户私钥 支付宝公钥...

Linux之epoll理解

IO多路复用有几种实现方式&#xff1a;select poll和epoll。本篇文章对epoll进行总结理解。 IO多路复用的含义&#xff0c;我个人的理解是通过一个线程实现对多个socket的侦听&#xff0c;epoll与select和poll的区别是epoll效率最高。select的最高管理1024个socket并且是通过轮…...

龟速乘 - a * b爆ll且模数很大时的计算方法

LL qmul(LL a, LL k, LL b) {LL res 0;while (k){if (k & 1) res (res a) % b;a (a a) % b;k >> 1;}return res; } 如果int128也会爆掉的话可以用这种方法 也是快速幂的思想&#xff0c;快速幂是乘&#xff0c;这个是加...

计算机网络笔记3 数据链路层

计算机网络系列笔记目录&#x1f447; 计算机网络笔记6 应用层计算机网络笔记5 运输层计算机网络笔记4 网络层计算机网络笔记3 数据链路层计算机网络笔记2 物理层计算机网络笔记1 概述 文章前言 &#x1f497; 站在巨人的肩膀上&#xff0c;让知识的获得更加容易&#xff01…...

如何实现矩阵的重采样问题

文章目录 前言一、问题描述二、回答 前言 记录知乎的自问自答。 一、问题描述 我的问题是这样的&#xff0c;有两个列向量E和F&#xff0c;需要注意的是&#xff0c;E和F是连续的&#xff0c;可任意插值&#xff0c;得到包含其中的子向量。E和F通过一个mn的矩阵联系起来&…...

Spring-事务管理-加强

目录 开启事务 编程式事务 声明式事务 声明式事务的优点 声明式事务的粒度问题 声明式事务用不对容易失效 Spring事务失效可能是哪些原因 Transactional(rollbackFor Exception.class)注解 Spring 事务的实现原理 事务传播机制 介绍 用法 rollbackFor 场景举例 …...

Minecraft个人服务器搭建自己的皮肤站并实现外置登录更换自定义皮肤组件

Minecraft个人服务器搭建自己的皮肤站并实现外置登录更换自定义皮肤组件 大家好&#xff0c;我是艾西有不少小伙伴非常喜欢我的世界Minecraft游戏&#xff0c;今天小编跟大家分享下Minecraft个人服务器怎么设置皮肤站。 Minecraft皮肤站是什么&#xff1f;其实官网就有皮肤站…...

解决ubuntu中没有网络连接的图标

现象&#xff1a;Ubuntu连接网络 在设置中没有显示网络图标 解决方案&#xff1a; 命令为 sudo nmcli networking off sudo nmcli networking on sudo service network-manager restart 重启ubuntu&#xff0c;网络连接完成...

数据结构基本概念-Java常用算法

数据结构基本概念-Java常用算法 1、数据结构基本概念2、数据逻辑结构3、算法时间复杂度 1、数据结构基本概念 数据&#xff08;Data&#xff09;&#xff1a;数据是信息的载体&#xff0c;其能够被计算机识别、存储和加工处理&#xff0c;是计算机程序加工的“原材料”。数据元…...

流程图设计制作都有哪些好用的工具

流程图是一种直观的图形表示方式&#xff0c;通常用于显示事物的过程、步骤和关系。在现代工作中&#xff0c;设计师经常需要绘制各种流程图来解释工作过程、产品设计等。本文将为您推荐7个流程图软件&#xff0c;以帮助您快速绘制高效的流程图&#xff0c;并提高工作效率。 即…...

2023-10-7

今日感冒了&#xff0c;整个人都不舒服&#xff0c;现在才 8 点&#xff0c;已经不想学习了。嗓子眼感觉不属于我了&#xff0c;痛死了。然后头也晕。 哎&#xff0c;今天又啥也没干 今日学习&#xff1a; 哎&#xff0c;今天就做了 RWCTF2022-Digging-into-kernel-2 这道题…...

【java源码】二甲医院his系统全套源码 云HIS系统源码

基层医院云HIS系统源码 一款满足基层医院各类业务需要的云HIS系统。该系统能帮助基层医院完成日常各类业务&#xff0c;提供病患挂号支持、病患问诊、电子病历、开药发药、会员管理、统计查询、医生站和护士站等一系列常规功能&#xff0c;还能与公卫、PACS等各类外部系统融合&…...

LRU 缓存 -- 哈希链表

相关题目 146. LRU 缓存 要让 put 和 get ⽅法的时间复杂度为 O(1)&#xff0c;我们可以总结出 cache 这个数据结构必要的条件&#xff1a; 1、显然 cache 中的元素必须有时序&#xff0c;以区分最近使⽤的和久未使⽤的数据&#xff0c;当容量满了之后要删除最久未使⽤的那个元…...

DWC数字世界大会先导论坛将于10月13日在宁波举办 | 数字技术赋能世界可持续发展

农业经济影响世界数千年&#xff0c;工业经济从欧美发源开始已有数百年&#xff0c;数字经济作为世界未来发展之大势&#xff0c;将成为影响未来数百年的世界命题。在以中国式现代化全面推进中华民族伟大复兴的历史征程中&#xff0c;数字技术、数字经济作为中国式现代化实践最…...

Springboot实现登录功能(token、redis、登录拦截器、全局异常处理)

登录流程&#xff1a; 1、前端调用登录接口&#xff0c;往接口里传入账号&#xff0c;密码 2、根据账号判断是否有这个用户&#xff0c;如果有则继续判断密码是否正确 3、验证成功后&#xff0c;则是根据账号&#xff0c;登录时间生成token&#xff08;用JWT&#xff09; 4、将…...

AI工程化—— 如何让AI在企业多快好省的落地?

文章目录 前言内容简介读者对象专家推荐目录赠书活动 前言 作为计算机科学的一个重要领域&#xff0c;机器学习也是目前人工智能领域非常活跃的分支之一。机器学习通过分析海量数据、总结规律&#xff0c;帮助人们解决众多实际问题。随着机器学习技术的发展&#xff0c;越来越多…...

mysqld_multi测试

mysqld_multi测试 mysql版本&#xff1a;5.7.25-log 在OS上分别安装了两套mysql&#xff0c; data目录为/mysql/mysql3306、 /mysql/mysql3307 。 端口分别为3306 、3307 配置文件为&#xff1a; /mysql/mysql3306/my.cnf /mysql/mysql3307/my.cnf 参考文档&#xff1a; htt…...

MDC方式实现简单链路追踪

MDC 方式实现日志链路追踪 拦截器 package com.cdn.log.interceptor;import com.cdn.log.consts.CLogConst; import com.cdn.log.utils.IdUtil; import org.slf4j.MDC; import org.springframework.util.StringUtils; import org.springframework.web.servlet.ModelAndView; im…...

Linux深度学习:除基本命令操作外的实用操作

Linux深度学习&#xff1a;除基本命令操作外的实用操作 软件安装systemctl软连接日期、时区IP地址、主机名网络传输下载和网络请求端口 进程管理主机状态系统资源监控磁盘信息监控网络状态监控 环境变量上传、下载压缩、解压root用户、用户、用户组管理查看、修改权限控制 软件…...

app对接广告变现平台:影响app广告单价的4大因素

在移动应用开发者和媒体公司竞相寻求提高广告变现效率的今天&#xff0c;理解影响APP广告单价的关键因素至关重要。广告单价是广告收入的核心组成部分&#xff0c;它受多种因素的影响&#xff0c;直接关系到媒体的盈利能力。主要因素大概有以下几点&#xff1a;#APP广告变现# …...

【数字化转型】10大数字化转型能力成熟度模型01(IOMM)

一、前言 数字化转型是数据化能力建设的目标和价值&#xff0c;作为一个新兴的课题&#xff0c;目前为止并未出现一个统一的数字化转型成熟度模型。不同的企业和机构&#xff0c;根据自身的发展和认知&#xff0c;推出了自己的企业级或者准行业级标准。这些标准具有很强的参考意…...

b2b网站对比/保定百度推广联系电话

1&#xff1a;“你相信有永远的爱吗?”“我相信的。” “你拥有过吗?”“还没有。” “那你为甚么相信?”“相信的话&#xff0c;比较幸福。” 2&#xff1a;我以为终有一天&#xff0c;我会彻底将爱情忘记&#xff0c;将你忘记&#xff0c; 可是&#xff0c;忽然有一天&…...

做网站要有什么功能/什么软件能搜索关键词能快速找到

该脚本可以用来导出IIS配置、任务计划、服务列表和APP&#xff0c;同时支持Windows 2003和2008。 #定义备份位置 $iisfolder "d:\Backup_all\IIS" $taskfolder "d:\Backup_all\Task" $servicesfolder "d:\Backup_all\Service" $appfolder &q…...

贵阳网站推广/网络推广优化是干啥的

作为DBA管理多台服务器通常都会需要从多台服务器收集信息。在SQL Server 2008通常的做法是用Linked server或者从单台服务器手机然后再将信息汇总到中央服务器。这些都需要很多额外的配置。 在SQL Server 2008中提供了一个新的功能&#xff0c;可以同时对多个服务器执行语句。 …...

做网站如何排版/外贸建站推广公司

A. 一农户在杀鸡前的晚上喂鸡&#xff0c;不经意地说&#xff1a;快吃吧&#xff0c;这是你最后一顿&#xff01;第二日&#xff0c;见鸡已躺倒并留遗书&#xff1a;爷已吃老鼠药&#xff0c;你们别想吃爷了&#xff0c;爷他妈也不是好惹的。当对手知道了你的决定之后&#xff…...

天眼查河南建设网站公司/干净无广告的搜索引擎

题目大意是给一个长度为n的整数序列&#xff0c;然后再给一个数num&#xff0c;然后将小于这个num的放在序列前面&#xff0c;等于num的放在序列中间&#xff0c;大于num的放在序列的后面&#xff0c;不要求排序&#xff0c;时间复杂度O&#xff08;n&#xff09;&#xff0c;空…...

教育网站建设的策划方案/成都关键词优化报价

基督教 赞美诗歌 Hymns Lyrics MP3 中文版 英文版 中英对照 MP3音频提取&#xff08;自动播放&#xff09;&#xff1a; http://filer.blogbus.com/5320797/resource_53207971262594667h.mp3 &#xff08;右击迅雷或目标另存为&#xff09; 词曲&#xff1a; 写作背景介绍&…...