一、分治的概念
“分治”是将难以直接解决的大问题,分解成若干规模较小的、相互独立的子问题,分而治之,再合成得到问题的解。
二、分治一般步骤
分解:将问题分解成若干子问题
解决:一一处理各个子问题,可采用递归
合并:将子问题合并成最终结果
三、分治常用领域
二分搜索:
bool bin_search(int L,int R){ //头尾指针
if(L<R){
int mid=(L+R)/2;
if(a[mid]==x) return 1;
else if(a[mid]>x) bin_search(L,mid);
else bin_search(mid+1,R);
}
else return 0;
}
快速排序:
#include<bits/stdc++.h>
#define MAXN 1000000
using namespace std;
int n,a[MAXN+1];
void qsort(int l, int r){
int i=l,j=r,mid=a[(i+j)/2];
do{ //先改变数值,后循环
while(a[i]<mid) i++;
while(mid<a[j]) j--;
if(i<=j){
swap(a[i],a[j]);
i++;j--;
}
}while(i<=j);
if(l<j) qsort(l,j);
if(i<r) qsort(i,r);
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
qsort(1,n);
for(int i=1;i<n;i++) printf("%d ",a[i]);
printf("%d",a[n]);
return 0;
}