考研要求掌握C语言(归并排序)

归并排序考啥?

在考研中归并排序只出在选择题,理解原理很重要

且在考研中考靓靓归并,还是比较简单的

归并排序原理

就是每次分一半,直到每一半只含有一个或不能再分时,一半一半的进行排序,最终合并两个有序的数组

代码实战

cpp 复制代码
//核心代码
void merge(int nums[],int low,int mid,int high)
{
    //合并数组两个有序的数组
    static int tmp[N];
    //创建一个和元数组一样大的数组进行合并,
    //加上static关键字是为了在递归过程中只创建一次
    for(int t=low;t<=high;t++)
    {
        tmp[t]=nums[t];//把当前low到high数据全部拷贝在临时数组中
    }
    
    //这里都是下标,所以可以等于
    int i,j,k;//注意k是合并数组的起始下标即low,千万别错
    for(k=low,i=low,j=mid+1;i<=mid && j<=high; k++)
    {
        if(tmp[i]<=tmp[j])
        {
            nums[k]=tmp[i++];
        }
        else
        {
            nums[k]=tmp[j++];
        }
    }
    //判断单独多余的那个,因为不知道哪一半数据是比另一半多的
    //所以要都判断
    while(i<=mid)
    {
        nums[k++]=tmp[i++];
    }
    while(j<=high)
    {
        nums[k++]=tmp[j++];
    }
    

}
 
void merge_sort(int nums[],int low,int high)
{
    if(low < high)
    {
        int mid = (low+high)/2;
        merge_sort(nums,low,mid);
        merge_sort(nums,mid+1,high);
        merge(nums,low,mid,high);
    }
}
 

可运行代码

cpp 复制代码
#include<stdio.h>
#include<string.h>
#include<time.h>
#include<stdlib.h>
#define N 10
void swap(int &a,int &b)
{
    int tmp=a;
    a=b;
    b=tmp;
}
 
 
void rangnums(int nums[],int len)
{
    srand(time(NULL));
    //初始化数组
    printf("初始化数组:");
    for(int i=0;i<len;i++)
    {
        nums[i]=rand()%100+1;
        printf("%d ",nums[i]);
    }
    puts("");
}
 
void print(int a[],int len)
{
    for(int i=0;i<len;i++)
    {
        printf("%d ",a[i]);
    }
    puts("");
}


void merge(int nums[],int low,int mid,int high)
{
    //合并数组两个有序的数组
    static int tmp[N];
    //创建一个和元数组一样大的数组进行合并,
    //加上static关键字是为了在递归过程中只创建一次
    for(int t=low;t<=high;t++)
    {
        tmp[t]=nums[t];//把当前low到high数据全部拷贝在临时数组中
    }
    
    //这里都是下标,所以可以等于
    int i,j,k;//注意k是合并数组的起始下标即low,千万别错
    for(k=low,i=low,j=mid+1;i<=mid && j<=high; k++)
    {
        if(tmp[i]<=tmp[j])
        {
            nums[k]=tmp[i++];
        }
        else
        {
            nums[k]=tmp[j++];
        }
    }
    //判断单独多余的那个,因为不知道哪一半数据是比另一半多的
    //所以要都判断
    while(i<=mid)
    {
        nums[k++]=tmp[i++];
    }
    while(j<=high)
    {
        nums[k++]=tmp[j++];
    }
    

}
 
void merge_sort(int nums[],int low,int high)
{
    if(low < high)
    {
        int mid = (low+high)/2;
        merge_sort(nums,low,mid);
        merge_sort(nums,mid+1,high);
        merge(nums,low,mid,high);
    }
}
 
 
int main()
{
    int a[N]={92 ,79 ,49, 59, 86 ,38, 94, 64, 92, 3};
    // rangnums(a,10);
    merge_sort(a,0,9);
    print(a,10);
    
}

时间复杂度

O(nlog2n)

空间复杂度

o(n)

相关推荐
waicsdn_haha7 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
嵌入式科普8 分钟前
十三、从0开始卷出一个新项目之瑞萨RZN2L串口DMA接收不定长
c语言·stm32·瑞萨·e2studio·rzn2l
_WndProc9 分钟前
C++ 日志输出
开发语言·c++·算法
薄荷故人_11 分钟前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
qq_4335545418 分钟前
C++ 面向对象编程:+号运算符重载,左移运算符重载
开发语言·c++
努力学习编程的伍大侠22 分钟前
基础排序算法
数据结构·c++·算法
数据小爬虫@37 分钟前
如何高效利用Python爬虫按关键字搜索苏宁商品
开发语言·爬虫·python
ZJ_.39 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
Narutolxy44 分钟前
深入探讨 Go 中的高级表单验证与翻译:Gin 与 Validator 的实践之道20241223
开发语言·golang·gin
XiaoLeisj1 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝