算法基础学习|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;
}
相关推荐
暖阳之下18 小时前
学习周报三十一
学习
程序员-King.18 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
BlockChain88818 小时前
字符串最后一个单词的长度
算法·go
爱吃泡芙的小白白18 小时前
深入解析:2024年AI大模型核心算法与应用全景
人工智能·算法·大模型算法
阿崽meitoufa19 小时前
JVM虚拟机:垃圾收集器和判断对象是否存活的算法
java·jvm·算法
Master_oid20 小时前
机器学习29:增强式学习(Deep Reinforcement Learning)④
人工智能·学习·机器学习
ballball~~20 小时前
拉普拉斯金字塔
算法·机器学习
Cemtery11620 小时前
Day26 常见的降维算法
人工智能·python·算法·机器学习
楼田莉子20 小时前
Linux学习之磁盘与Ext系列文件
linux·运维·服务器·c语言·学习
一条闲鱼_mytube20 小时前
智能体设计模式(三)多智能体协作-记忆管理-学习与适应
人工智能·学习·设计模式