题解 | #二分查找-I#
二分查找-I
https://www.nowcoder.com/practice/d3df40bd23594118b57554129cadf47b
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型vector
* @param target int整型
* @return int整型
*/
int search(vector<int>& nums, int target) {
// write code here
if (nums.size() == 0)return -1;
if (nums.size() == 1) {
if (nums[0] == target)return 0;
else return -1;
}
int length = nums.size();
int res = 0;
while (length) {
if (nums[length / 2] > target) {
vector<int>::const_iterator be = nums.begin();
vector<int>::const_iterator en = nums.begin() + (length / 2);
if (length != 1)nums.assign(be, en);
else return -1;
} else if (nums[length / 2] < target) {
vector<int>::const_iterator be = nums.begin() + (length / 2) + 1;
vector<int>::const_iterator en = nums.end();
if (length != 1)nums.assign(be, en);
else return -1;
res += length / 2 + 1;
} else {
res += length / 2;
return res;
}
length = nums.size();
}
return -1;
}
};
比较简单,要注意的一个细节就是vector容器的assign方法中第二个参数(即结束迭代器)指示的是截取到这个迭代器前一个位置。
时间复杂度Ologn,空间复杂度为常数。
查看1道真题和解析