【归并排序】 详细解析 动图演示 逐图解析 洛谷P1177【模板】排序 sort【快速排序】

文章目录

    • 归并排序
      • 1.归并排序的复杂度分析
      • 2.细节解释
      • 3.归并排序动图演示
        • 3(1) 我们的拆分过程如下↓
      • 4.code↓
    • 洛谷P1177【模板】排序
      • 数据规模与约定
      • code(归并排序)↓
      • code(sort排序【快速排序】)
    • 完结撒花( ̄▽ ̄) /

归并排序

归并排序(merge sort)是高效的基于比较的稳定排序算法。

1.归并排序的复杂度分析

归并排序的时间复杂度 O ( n l o g n ) O(nlogn) O(nlogn)

归并排序的空间复杂度 O ( n ) O(n) O(n)(这是因为他不是原地排序算法

2.细节解释

( l + r ) > > 1 = ( l + r ) ÷ 2 1 = ( l + r ) ÷ 2 (l+r)>>1=(l+r)\div 2^{1}=(l+r)\div 2 (l+r)>>1=(l+r)÷21=(l+r)÷2;

3.归并排序动图演示

在这里我们是默认了它以中间为节点分别排成了从大到小两个序列

这是因为有merge_sort(q,l,mid),merge_sort(q,mid+1,r)不断进行拆分的原因

3(1) 我们的拆分过程如下↓

在这里插入图片描述

这里的动图演示先执行了下方代码

	int k=0,i=l,j=mid+1;//i表示左半边的开始,j表示右半边的开始,k表示合并的个数while(i<=mid&&j<=r){//对半分后,mid是i的终点,r是j的终点if(q[i]<=q[j])  tmp[k++]=q[i++];//不断将tmp填充,i++else tmp[k++]=q[j++];//else 等同于if(q[i]>q[j]) }

q[i]q[j]已经超过了他们的终点i终点midj终点r),那么就执行下方代码

	while(i<=mid) tmp[k++]=q[i++];//将i没有填充完的继续进行填充while(j<=r) tmp[k++]=q[j++];//将j没有填充完的继续进行填充

执行上方代码时一定有一个值(i or j) 是已经超过了他们的终点的,不然不会退出循环,所以不用考虑大小关系

执行上方代码是为了将剩下的可以填充的数填充进tmp数组里,以此来保证没有遗漏

动图演示↓
在这里插入图片描述

4.code↓

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+10;
int n,a[maxn] ,tmp[maxn];
void merge_sort(int q[],int l,int r){//要排序的数组,左边界,有边界if(l>=r) return;//不满足要求int mid=(l+r)>>1;//m是l+r的中间值,(l+r)>>1=(l+r)/(2^{1})=(l+r)/2;merge_sort(q,l,mid),merge_sort(q,mid+1,r);//不断将它进行拆分,然后归并int k=0,i=l,j=mid+1;//i表示左半边的开始,j表示右半边的开始,k表示合并的个数while(i<=mid&&j<=r){//对半分后,mid是i的终点,r是j的终点if(q[i]<=q[j])  tmp[k++]=q[i++];//不断将tmp填充,i++else tmp[k++]=q[j++];//else 等同于if(q[i]>q[j]) }while(i<=mid) tmp[k++]=q[i++];//将i没有填充完的继续进行填充while(j<=r) tmp[k++]=q[j++];//将j没有填充完的继续进行填充for(int i=l,j=0;i<=r;i++,j++){q[i]=tmp[j];//将已经排好序的(tmp[l]~tmp[r])给赋值到q数组}
}
int main(){ios::sync_with_stdio(false);//加速cincin.tie(0),cout.tie(0);cin>>n;for(int i=0;i<n;i++){cin>>a[i];//输入数列}merge_sort(a,0,n-1);//进行排序for(int i=0;i<n;i++){cout<<a[i]<<" ";//进行排好序了的进行输出}return 0;
}

洛谷P1177【模板】排序

题意:将读入的 N N N个数从小到大排序后输出

数据规模与约定

对于 20 % 20\% 20% 的数据,有 1 ≤ N ≤ 1 0 3 1 \leq N \leq 10^3 1N103

对于 100 % 100\% 100% 的数据,有 1 ≤ N ≤ 1 0 5 1 \leq N \leq 10^5 1N105 1 ≤ a i ≤ 1 0 9 1 \le a_i \le 10^9 1ai109

code(归并排序)↓

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+10;
int n,a[maxn] ,tmp[maxn];
void merge_sort(int q[],int l,int r){if(l>=r) return;int mid=(l+r)>>1;merge_sort(q,l,mid),merge_sort(q,mid+1,r);int k=0,i=l,j=mid+1;while(i<=mid&&j<=r){if(q[i]<=q[j])  tmp[k++]=q[i++];else tmp[k++]=q[j++];}while(i<=mid) tmp[k++]=q[i++];while(j<=r) tmp[k++]=q[j++];for(int i=l,j=0;i<=r;i++,j++){q[i]=tmp[j];}
}
int main(){ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);cin>>n;for(int i=0;i<n;i++){cin>>a[i];}merge_sort(a,0,n-1);for(int i=0;i<n;i++){cout<<a[i]<<" ";}return 0;
}

code(sort排序【快速排序】)

#include <bits/stdc++.h>
using namespace std;
const int maxn=1e5+5;
int n,a[maxn]={};
int main(){cin>>n;for(int i=1;i<=n;i++) cin>>a[i];sort(a,a+1+n);for(int i=1;i<=n;i++) cout<<a[i]<<" ";return 0;
}

完结撒花( ̄▽ ̄) /

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

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

相关文章

简析:老阳蓝海项目怎么做才能赚钱?

在互联网的浪潮中&#xff0c;新的商业模式和项目层出不穷&#xff0c;其中&#xff0c;老阳蓝海项目因其独特的市场定位和创新模式&#xff0c;吸引了许多人的关注。但是&#xff0c;如何在老阳蓝海项目中实现盈利&#xff0c;却是一个需要深入探讨的问题。 首先&#xff0c;要…

CorelDRAW2024中文免费版功能强大的矢量图形设计软件

CorelDRAW 2024是一款功能强大的矢量图形设计软件&#xff0c;广泛应用于广告制作、包装设计、插画设计、服装设计、网页设计等多个领域。以下是对其功能的详细介绍&#xff1a; 矢量图形设计&#xff1a;CorelDRAW 2024提供了全面的矢量图形设计功能&#xff0c;包括绘制基本…

hnust 湖南科技大学 2023 综合实训3(软件工程)课设 完整代码及数据库+报告+uml等图源文件+指导书

hnust 湖南科技大学 2023 综合实训3&#xff08;软件工程&#xff09;课设 完整代码及数据库报告uml等图源文件指导书 介绍 老师考核等级为优&#xff0c;系统多次测试&#xff0c;未发现bug 项目前后端分离&#xff0c;前端vue2工程项目&#xff0c;后端springboot&#xff…

10万㎡!天府新区又一重大成都直播产业园正在投用

天府新区&#xff0c;作为成都乃至整个四川省的新经济增长极&#xff0c;正以其独特的魅力和强大的发展势头吸引着世界的目光。今天&#xff0c;我们有幸在这里见证一个崭新的里程碑——10万㎡的成都直播产业园&#xff1a;天府锋巢直播产业基地 正式投入使用。这不仅是对天府新…

蜂窝物联:物联网大数据云平台功能模块简介

蜂窝云平台可远程获取现场环境&#xff08;如温室大棚、稻田&#xff09;的空气温湿度、土壤水分温度、二氧化碳浓度、光照强度及视频图像&#xff0c;通过数据模型分析&#xff0c;可以自动控制湿帘、风机、喷淋滴灌、内外遮阳、顶窗侧窗、加温补光、增氧机等设备&#xff1b;…

Python算法100例-3.1 回文数

完整源代码项目地址&#xff0c;关注博主私信源代码后可获取 1.问题描述2.问题分析3.算法设计4.确定程序框架5.完整的程序6.问题拓展7.巧用字符串技巧 1&#xff0e;问题描述 打印所有不超过n&#xff08;取n<256&#xff09;的其平方具有对称性质的数&#xff08;也称回…

H.266参考软件VTM各版本的性能差异

VTM&#xff08;VVC Test Model&#xff09;&#xff0c;是H.266视频编码标准的参考软件&#xff0c;即是VVC spec.的一种参考实现&#xff0c;代码里包括了H.266的软件编码器和软件解码器实现&#xff0c;代码地址如下&#xff1a; https://vcgit.hhi.fraunhofer.de/jvet/VVCS…

如何做代币分析:以 INJ 币为例

如何做代币分析&#xff1a;以 INJ 币为例 作者&#xff1a; lesleyfootprint.network 编译&#xff1a;cicifootprint.network 数据源&#xff1a;INJ 代币仪表板 &#xff08;仅包括以太坊数据&#xff09; 在加密货币和数字资产领域&#xff0c;代币分析起着至关重要的作…

tomcat nginx 动静分离

实验目的:当访问静态资源的时候&#xff0c;nginx自己处理 当访问动态资源的时候&#xff0c;转给tomcat处理 第一步 关闭防火墙 关闭防护 代理服务器操作&#xff1a; 用yum安装nginx 然后写配置文件&#xff0c;yum安装的nginx主配置文件默认为/etc/nginx/nginx.conf

程序员如何选择职业赛道?

一、自我评估与兴趣探索 程序员选择职业赛道时&#xff0c;可以考虑以下几个关键因素&#xff1a; 1、兴趣与热情&#xff1a;首先要考虑自己的兴趣和热情&#xff0c;选择符合个人喜好和激情的领域&#xff0c;能够激励自己持续学习和进步。 2、技术能力&am…

乡村集中污水处理需要哪些工艺设备

乡村集中污水处理是解决乡村环境污染问题的重要举措&#xff0c;而要实现高效的污水处理&#xff0c;必须配备合适的工艺设备。以下是乡村集中污水处理常用的工艺设备&#xff1a; 1. 溶氧设备&#xff1a;在污水处理过程中&#xff0c;溶解氧的供给对于维持微生物生长和有机物…

绝地求生:¥PUBG财富秘籍¥ 我在荣都砸锅卖铁之我要当首富

在荣都市场系统上线以来&#xff0c;想必现在大家已经很熟练的赚钱了。除了给的赏金任务给欧皇的巨额BR币以外&#xff0c;那肯定还有很多玩家会收到各式各样奇葩奖励的任务&#xff0c;下面看看这些奇葩任务。 但也有欧皇任务给了巨额RP币 除了做任务&#xff0c;当然还有去摸…