• 归并排序算法代码


    #include 
    #include 
    #include 
    void print_arr(int arr[],int n);//打印数组函数 
    void msort(int arr[] , int tempArr[] , int left , int right);//归并排序函数 
    void merge(int arr[],int tempArr[],int left,int mid,int right);//合并函数 
    void merge_sort(int arr[] , int n);//归并排序入口 
    void print_arr(int arr[],int n)
    {
    	for(int i = 0 ; i < n ; i++){
    		printf("%4d",arr[i]);
    	}
    	putchar('\n');
    }
    void msort(int arr[] , int tempArr[] , int left , int right)
    {
    	//如果只有一个元素,那么不需要继续划分
    	//只有一个元素的区域,本生就是有序的,只需要被归并即可
    	if(left < right){
    		//找中间点
    		int mid = (left + right)/2;
    		//递归划分左半区
    		msort(arr,tempArr,left,mid);
    		//递归划分右半区
    		msort(arr,tempArr,mid+1,right);
    		//合并已经排序的部分
    		merge(arr,tempArr,left,mid,right);
    	} 
    }
    void merge_sort(int arr[] , int n)
    {
    	//分配一个辅助数组
    	int *tempArr = (int *)malloc(n * sizeof(int));
    	if(tempArr){
    		msort(arr,tempArr,0,n-1);
    		free(tempArr);
    	}else{
    		printf("error:failed to allocate memory");
    	} 
    }
    void merge(int arr[],int tempArr[],int left,int mid,int right)
    {
    	//标记左半区第一个未排序的元素
    	int l_pos = left; 
    	//标记右半区第一个未排序的元素
    	int r_pos = mid+1;
    	//临时数组元素的下标
    	int pos = left;
    	//合并
    	while(l_pos <= mid && r_pos <= right){
    		if(arr[l_pos] < arr[r_pos]){
    			//左半区第一个剩余元素更小 
    			tempArr[pos++] = arr[l_pos++];
    		}else{
    			//右半区的第一个剩余元素更小 
    			tempArr[pos++] = arr[r_pos++];
    		}
    	}
    	//合并左半区剩余的元素
    	while(l_pos <= mid){
    		tempArr[pos++] = arr[l_pos++];
    	} 
    	//合并右半区剩余的元素
    	while(r_pos <= right){
    		tempArr[pos++] = arr[r_pos++];
    	}
    	//把临时数组中合并后的元素复制回原来的数组 
    	while(left <= right){
    		arr[left] = tempArr[left];
    		left++; 
    	}
    }
    int main()
    {
    	int arr[] = {9,5,2,7,12,4,3,1,11};
    	int n = 9;
    	print_arr(arr,n);
    	merge_sort(arr,n);
    	print_arr(arr,n);
    	return 0;
    } 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
  • 相关阅读:
    linux中断
    K8S:K8S自动化运维容器Docker集群
    C语言学生成绩管理系统(二叉排序树)
    HC32F120开发之IAP
    Nginx、MySQL、LNMP安装
    Unity工具 - 工具聚合页(UEWindow)
    JavaScript ES6类的定义与继承
    matlab 实现点云ICP 配准算法
    多版本node的安装与切换详细操作
    MySQL约束
  • 原文地址:https://blog.csdn.net/weixin_55804957/article/details/127941916