C语言用分治法实现数组归并排序算法实现

本文介绍了如何使用分治法解决归并排序问题,包括问题分解、递归过程以及合并子问题的策略。通过代码实例展示了如何在C++中实现归并排序算法,强调了其实质是将大问题分解为小问题并合并解决的过程。
摘要由CSDN通过智能技术生成

目的:

1.掌握能用分治法求解的问题应满足的条件;

2.加深对分治法算法设计方法的理解与应用;

3.锻炼学生对程序跟踪调试能力;

4.通过本次实验的练习培养学生应用所学知识解决实际问题的能力。

问题:

输入N个数对其进行归并排序。

解决策略:

分治法策略:

          问题可以简化为在n个数里面寻找最大和最小值。

(1)将数据等分为两组(两组数据的个数可能相差1),目的是分别选取其中的最大(小)值。

(2)递归分解直到每组元素的个数<=2,则可以简单地找到其中的最大(小)值。

(3)回溯时合并子问题的解,在两个子问题的解中大者取大,小者取小,即合并为当前问题的解。

归并排序的过程是,将数组分为许多的组,即将数组元素多的数组分为数组元素少的数组,然后再将其合并。它的优点是,同时对多个数据进行对比排序,归并排序是分治法的典型应用。
分:体现在将数组分为小数组。
治:对排好序的数组进行合并。

代码实现:

#include<bits/stdc++.h>
using namespace std;
void Mergearray(int a[],int first,int mid,int last,int temp[])	//将两个有序数组合并排序 
{
	int i=first,j=mid+1;
	int m=mid,n=last;
	int k=0;
	while(i<=m&&j<=n)
	{
		if(a[i]<a[j])
			temp[k++]=a[i++];
		else
			temp[k++]=a[j++];
	}
	while(i<=m)
		temp[k++]=a[i++];
	while(j<=n)
		temp[k++]=a[j++];
	for(i=0;i<k;i++)
		a[first+i]=temp[i];
}
 
void Mergesort(int a[],int first,int last,int temp[])	//将两个任意数组合并排序 
{
	if(first<last)
	{
		int mid=(first+last)/2;
		Mergesort(a,first,mid,temp);	//左边有序 
		Mergesort(a,mid+1,last,temp);	//右边有序 
		Mergearray(a,first,mid,last,temp);	//再将两个有序数组合并 
	}
}
 
bool MergeSort(int a[], int n)  
{  
    int *p = new int[n];  //分配一个有n个int型元素的数组所占空间,并将该数组的第一个元素的地址赋给int *型指针p。
    if (p == NULL)  
        return false;  
    Mergesort(a, 0, n - 1, p);  
    delete[] p;  
    return true;  
} 
 
int main()
{
	int a[1000];
	int n;
	printf("请输入数的个数:\n");
	scanf("%d",&n);
	printf("请输入要排序的数列:\n");
	for(int i=0;i<n;i++)
		scanf("%d",&a[i]);
	MergeSort(a,n);
	printf("排序结果为:");
	for(int i=0;i<n;i++)
		printf(" %d ",a[i]);
} 

运行结果:

  • 16
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
归并排序是一种分治算法,将待排序序列递归地分成两个子序列,对这两个子序列分别进行排序,最后将两个有序子序列合并为一个有序序列。下面是c语言实现归并排序的代码: ```c #include<stdio.h> #include<stdlib.h> void merge(int arr[], int left, int mid, int right) { int i, j, k; int n1 = mid - left + 1; int n2 = right - mid; int L[n1], R[n2]; for (i = 0; i < n1; i++) L[i] = arr[left + i]; for (j = 0; j < n2; j++) R[j] = arr[mid + 1 + j]; i = 0; j = 0; k = left; while (i < n1 && j < n2) { if (L[i] <= R[j]) { arr[k] = L[i]; i++; } else { arr[k] = R[j]; j++; } k++; } while (i < n1) { arr[k] = L[i]; i++; k++; } while (j < n2) { arr[k] = R[j]; j++; k++; } } void mergeSort(int arr[], int left, int right) { if (left < right) { int mid = left + (right - left) / 2; mergeSort(arr, left, mid); mergeSort(arr, mid + 1, right); merge(arr, left, mid, right); } } int main() { int n, i; printf("Enter the number of elements: "); scanf("%d", &n); int arr[n]; printf("Enter the elements: "); for (i = 0; i < n; i++) scanf("%d", &arr[i]); mergeSort(arr, 0, n - 1); printf("Sorted array: "); for (i = 0; i < n; i++) printf("%d ", arr[i]); return 0; } ``` 该程序首先使用merge函数将两个有序子数组合并为一个有序数组,然后使用mergeSort函数将待排序数组分成两个子数组,分别对这两个子数组进行递归排序。在merge和mergeSort函数中,使用了左指针left,右指针right和中间指针mid来控制数组的分割和合并。最后在主函数中输入待排序数组并调用mergeSort函数进行排序,输出排序后的数组

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

涣清。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值