关于二分查找

一:

/*

关于二分查找:

1.查找目标值:

当right=nums.size()-1时,判定条件应该为left<=right  right赋值时也应该是mid-1;

当right=nums.size()时,判定条件应该为left<right  right赋值时也应该是mid;
*/

/*2. 查找第一个不小于(>=)目标值的数*/

int search(vector<int>& nums, int target)

{

int pos;

int left = 0;

int right = nums.size() ;

while (left < right)

{

int mid = left + (right-left) / 2;

if (nums[mid] < target)

left = mid + 1;

else right = mid;

}

return right;

}

/*可变形为查找最后一个小于(<)目标值的数:上述代码最后返回right-1;*/

/*3. 查找第一个大于(>)目标值的数*/

int search(vector<int>& nums, int target)

{

int left = 0;

int right = nums.size() - 1;

while (left < right)

{

int mid = left + (right-left) / 2;

if (nums[mid] <= target)

left = mid + 1;

else right = mid;

}

return right;

}
/*

返回最后一个相同的数字的下一个位置。

if (nums[mid] <= target) 判定条件多了一个等号

最后返回为right-1;

    可变形为查找最后一个不大于(<=)目标值的数:最后返回为right-1;

*/
#include<iostream>

using namespace std;

int BinFindValue(int* arr, int left, int right,int key)//递归二分查找

{

int pos = -1;

if (left>right)

{

return pos;

}

int mid = (right - left + 1) / 2 + left;

if (arr[mid] == key)

{

pos = mid;

}

if (arr[mid] < key )

{

return BinFindValue(arr,mid+1,right,key);

}

if (arr[mid] > key)

{

return BinFindValue(arr, left, mid - 1,key);

}


}

int BinFindValueNice(int* arr,int len,int key)//非递归二分查找

{

int pos = -1;

if (arr == NULL || len <= 0)

{

return pos;

}

int left = 0;

int right = len - 1;

while (left<=right)

{

int mid = (right-left+1) / 2 + left;

if (key < arr[mid])

{

right = mid - 1;

}

else if (key > arr[mid])

{

left = mid + 1;

}

else

{

while (mid > left && key == arr[mid - 1]) --mid;

pos = mid;

break;

}

}

return pos;

}

int main()

{

int arr[] = {3,5,7,9,16,15,46,55};

int len = sizeof(arr) / sizeof(arr[0]);

cout << BinFindValueNice(arr,len,5) << endl;

cout << BinFindValue(arr,0,len-1,55) << endl;

return 0;

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值