好的,所以我得到了这个功能
int bin(int value, int size, int array[])
我应该在“array[]”中找到“value”,但这里的问题是,在大多数情况下,我们有一些类似的东西
int bin(int value, int max, int min, int array[])
从逻辑上讲,这部分的递归要容易得多,因为我仍然可以传递我所在的数字,并记住数组的大小。
int bin(int array[], int value, int min, int max)
{
if(max < min)
return -1;
else
{
int mid = min + (max - min)/2;
if(array[mid] > value)
return bin(array, value, min, mid-1);
else if(array[mid] < value)
return bin(array, value, mid+1, max);
else
return mid;
}
但是由于我只能传递 1 个整数,我该如何调整这个算法呢?从本质上讲,我只能做这样的事情,但我知道这在逻辑上是行不通的。不过,有没有办法让我看到数组的大小?我试过了,但数字不正确。
int bin(int array[], int value, int size)
{
int mid = size/2;
if(array[mid] > value)
return bin(array, value, size-(size/2));
else if(array[mid] < value)
return bin(array, value, size+(size/2));
else
return mid;
}