分治小结mooc

分治

基本概念

把一个任务,分成形式和原任务相同,但规模更小的几个部分任务(通常是两个部分),分别完成,或只需选一部分完成。然后在处理完成后的这一个或几个部分的结果,完成整个个任务的完成。

归并排序(分治的典型应用)

思路

1、把前一半排序
2、将后一半排序
3、把两半归并到一个新的有序数组,然后再拷贝回原数组,排序完成。

程序详情

#include<iostream>
using namespace std;
void Merge(int a[], int s, int m, int e, int tep[])
{
	int pb=0;
	int p1=s,p2=m+1;
	while(p1<=m && p2<=e)
	{
		if(a[p1]<a[p2])
			tep[pb++]=a[p1++];
		else
			tep[pb++]=a[p2++];
			
	}
	while(p1<=m)
		tep[pb++]=a[p1++];
	while(p2<=e)
		tep[pb++]=a[p2++];
	for(int i=0;i<e-s+1;i++)
		a[s+i]=tep[i];
}

void MergeSort(int a[],int s, int e, int tep[])
{
	if(s<e)
	{
		int m=s+(e-s)/2;
		MergeSort(a,s,m,tep);
		MergeSort(a,m+1,e,tep);
		Merge(a,s,m,e,tep);
	}
}
int a[10]={13,27,19,2,8,12,2,8,30,89};
int b[10];

int main()
{
	int size=sizeof(a)/sizeof(int);
	MergeSort(a,0,size-1,b);
	for(int i=0;i<size;i++)
	cout<<a[i]<<",";
	cout<<endl;
	return 0;
}

补充函数

siziof(a):表示a这个变量占了多少个字节。
sizeof(int):表示int型的变量占了多少个字节。
整个表达式的意思是将上述两者相除的结果赋值给n。
还运用到了指针来改变主函数中数据位置。

快速排序

思路

1、设k=a[ ],将k挪到合适位置,使得比k小的元素都在k左边,比k大的元素都在k右边,和k相等的,不关心在k左右出现均可(O(n)时间内完成)
2、把k左边的部分快速排序
3、把k右边的部分快速排序

代码详情

#include<iostream>
using namespace std;
void swap(int &a,int &b)
{
	int tep=a;
	a=b;
	b=tep;
}//交换变量
 
void QuickSort(int a[],int s, int e)
{
	if(s>=e)
	return;
	int k=a[s];
	int i=s,j=e;
	while(i!=j)
		{
			while(j>i && a[j]>=k)
				j--;
			swap(a[i],a[j]);
			while(i<j && a[i]<=k)
				i++;
			swap(a[i],a[j]);
		}//处理完后,a[i]=k;
	QuickSort(a,s,i-1);
	QuickSort(a,i+1,e); 
}
int a[]={93,27,30,2,8,12,2,8,30,89};
int main()
{
	int size=sizeof(a)/sizeof(int);
	QuickSort(a,0,size-1);
	for(int i=0;i<size;i++)
		cout<<a[i]<<",";
		cout<<endl;
		return 0;
}

补充说明

函数中运用了c++中的取地址符来改变原函数的数组内值的位置

void swap(int &a,int &b)

计算机201 qyj

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值