金块(最大、最小金块)二分法查询

C语言实现金块二分法查找

二分法是分治法的一种

将一个难以直接解决的大问题,分割成一些规模较小的相同问题,以便各个击破,分而治之。


首先来初步认识一下二分法:
递归以及非递归方法
如果查找数组里面的某个数
首先确保数组是有序的
顺序(以升序数组为例)
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;
  }
}

你可能感兴趣的:(金块(最大、最小金块)二分法查询)