将一个难以直接解决的大问题,分割成一些规模较小的相同问题,以便各个击破,分而治之。
如果查找数组里面的某个数
首先确保数组是有序的
顺序(以升序数组为例)
1.确定数组的头尾,用标识记录(high,low)
从中间元素(mid)搜索是就返回
2.不是中间数就看要找的数比中间数大还是小
大(小)的话就在中间数的右(左)半部分找
high=mid+1(low=mid-1)重复1操作
3.直到找到数或者high>low结束
非递归查找
#include
#include
//非递归算法
int Bin_Search(int *arr,int length,int find)
{
int first = 0,last = length-1,mid;
int sum = 0;
while(first <= last)
{
sum ++;
mid = (first + last)/2;//确定中间元素
if(arr[mid] > find) //寻找数在前面
{
last = mid-1;
}
else if(arr[mid] < find)//寻找数在后面
{
first = mid+1;
}
else //判断是否相等
{
printf("查找次数:%d\n",sum);
return mid;
}
}
printf("查找次数:%d\n",sum);
return -1;
}
递归查找
//递归算法
int bin_Search(int *arr,int find,int high,int low){
if(low<=high){
int mid=(high+low)/2;
if(arr[mid] > find){
return bin_Search(arr,find,mid-1,low);
}
if(arr[mid] < find){
return bin_Search(arr,find,high,mid+1);
}
else return mid;
}
return -1;
}
主函数
void main(void)
{
int find,a=0;
int arr[10] = {1,2,3,4,5,6,7,8,10};
printf("1是递归,2是非递归:\n");
scanf("%d",&a);
switch(a){
case 1:
printf("递归,请输入您要查找的数字:\n");
scanf("%d",&find);
int found=bin_Search(arr,find,9,0);
if(found==-1){
printf("无该数字!!\n");
}
else {
printf("这个数在数组的位置:%d",found);
}
break;
case 2:
printf("非递归,请输入您要查找的数字:\n");
scanf("%d",&find);
int site = Bin_Search(arr,10,find);
if(site!=-1) {
printf("数字在数组的位置:%d\n",site);
}
else printf("无该数字!!\n");
}
}
找最大、小金块 —— 二分法
原数组可以是无序,只需要递归分解问题直到分解到数组只有一个或两个元素,这样就形成了有序的数组,通过指针返回最大最小值。
int main()
{
int a[10]={5,2,3,4,5,77,7,5,3};
int max=0,min=99,i=0,j=8; //i是头 j是尾
maxmin(i,j,&max,&min,a);
printf("max=%d ,min=%d",max,min);
}
void maxmin(int i,int j,int *max,int *min,int *a){
int mid=0;
if(i==j){ //只有1个的情况结束递归
*max=a[i]; *min=a[i];
}else if(j==i+1){ //只有2个的情况结束递归
if(a[i]<a[j]){
*max=a[j];
*min=a[i];
}else {
*max=a[i];
*min=a[j];
}
} else{ //需要继续划分的情况
mid=(i+j)/2;//4
maxmin(i,mid,max,min,a); //前半部分
int min1=*min;
int max1=*max;
maxmin(mid+1,j,max,min,a); //后半部分
if(min1<*min) *min=min1;
if(max1>*max) *max=max1;
}
}