算法基础学习|02归并排序——分治

一、思路

(1)确定分界点:mid=(l+r)/2 ------这里和快排不同

(2)递归排序(left right)

(3)归并------合二为一

时间复杂度nlogn

二、题目练习

三、模板

归并排序

复制代码
#include<bits/stdc++.h>
using namespace std;

const int N=1e5+10;

int q[N],tmp[N];
int n;

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(i=l,j=0;i<=r;i++,j++)q[i]=tmp[j];
    
}

int main()
{
    scanf("%d",&n);
    for(int i=0;i<n;i++)scanf("%d",&q[i]);
    
    merge_sort(q,0,n-1);
    
    for(int i=0;i<n;i++)printf("%d ",q[i]);
    
    return 0;
}

逆序对的数量

复制代码
#include<iostream>
using namespace std;

const int N = 1e5+10;
int q[N],tmp[N];
int n;
long long result=0;

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++];
            result+=mid-i+1;
        }
    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()
{
    scanf("%d",&n);
    for(int i=0;i<n;i++)scanf("%d",&q[i]);
    
    merge_sort(q,0,n-1);
    
    printf("%lld",result);
    
    return 0;
}
相关推荐
冷崖14 分钟前
网络学习-利用reactor实现http请求(六)
网络·学习·http
钟烁卓18 分钟前
C++日志
开发语言·c++
浪浪山小白兔22 分钟前
CMake跨平台编译生成:从理论到实战
c++
啊吧怪不啊吧30 分钟前
C++之初识模版
开发语言·数据结构·c++
YKPG34 分钟前
C++学习-入门到精通-【7】类的深入剖析
c++·学习·算法
wusixuan1310041 小时前
图论学习笔记 3
笔记·学习·图论
whoarethenext1 小时前
c/c++的opencv模糊
c语言·c++·opencv
vivo互联网技术1 小时前
vivo官网APP首页端智能业务实践
前端·深度学习·算法
JK0x071 小时前
代码随想录算法训练营 Day49 图论Ⅰ 深度优先与广度优先
算法·深度优先·图论
nenchoumi31191 小时前
Model 速通系列(一)nanoGPT
笔记·深度学习·学习·语言模型