归并排序 刷题笔记

归并排序的写法

归并排序

分治+双指针

1.定义一个mid

if(l>=r)return ;

2.分治

sort(q,l,mid);

sort(q,mid+1,r);

双指针

int i=l,j=mid,k=0;

将双序列扫入 缓存数组

条件 while(i<=mid&&j<=r)

两个数列比较大小 小的一方 进入缓存数组

扫尾

while(i<=mid) tempk++=qi++;

while(j<=r) tempk++=qj++;

复制 回去修改q\[\]数组的值

for (int i=l,j=0;i<=mid;i++,j++){

qi= tempj;

}

代码

include<iostream>

#include<cstdio>

#include<cstring>

#include<algorithm>

#include<sstream>

const int N=1e5+10;

int qN,tempN;

int n;

void quick_sort(int q\[\],int l,int r){

if(l>=r){

return ;

}

int mid =(l+r)>>1;

quick_sort(q,l,mid);

quick_sort(q,mid+1,r);

int i=l,j=mid+1,k=0;

while(i<=mid&&j<=r){

if(qi<=qj){

tempk++=qi++;

}else{

tempk++=qj++;

}

}

while(i<=mid){

tempk++=qi++;

}

while(j<=r){

tempk++=qj++;

}

for(int i=l,j=0;i<=r;i++,j++){

qi=tempj;

}

}

using namespace std;

int main(){

int n;

cin>>n;

for(int i=0;i<n;i++){

scanf("%d",&qi);

}

quick_sort(q,0,n-1);

for(int i=0;i<n;i++){

printf("%d ",qi);

}

return 0;

}

相关推荐
右耳朵猫AI1 分钟前
Java/JVM周刊2026W21 | Java 26发布、JDK 27抢先体验、Spring Boot 4.1预告、GlassFish 8.0.2发布
java·jvm·spring boot
Knight_AL3 分钟前
MyBatis 报错:Parameter ‘xxx‘ not found 的原因与解决方案
java·tomcat·mybatis
一条泥憨鱼6 分钟前
Java网络编程:Socket通信从入门到起飞
java·开发语言·网络·网络编程
05候补工程师7 分钟前
【期末/408冲刺】软件工程核心考点与大题通关秘籍(附图解与解题套路)
大数据·hadoop·经验分享·笔记·软件工程
西安邮电大学10 分钟前
分布式锁三种实现
java·redis·后端·其他·面试
超人不会飞_Jay11 分钟前
2026.6.4 Vue用户中心项目笔记
前端·vue.js·笔记
码不停蹄的玄黓14 分钟前
SpringBoot 实现自定义注解
java·spring boot·spring
中屹指纹浏览器14 分钟前
2026WebGL2着色器浮点精度与帧缓存像素指纹溯源及内核渲染层差异化改造详解
经验分享·笔记
施棠海20 分钟前
自定义并可深度定制的数字滚动选择器完整源代码与相关注意事项
java·开发语言
YunQuality20 分钟前
老牌连接器大厂盛凌电子启动QMS数字化升级:制造企业的质量内卷,终于不靠“人盯人”了
笔记·制造·职场·工业软件