分治
基本概念
把一个任务,分成形式和原任务相同,但规模更小的几个部分任务(通常是两个部分),分别完成,或只需选一部分完成。然后在处理完成后的这一个或几个部分的结果,完成整个个任务的完成。
归并排序(分治的典型应用)
思路
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