题解 | #牛群的位置排序#
牛群的位置排序
https://www.nowcoder.com/practice/87c81fa27b9a45c49ed56650dfa6f51b
题目考察的知识点:二分查找
题目解答方法的文字分析:先用二分法查找,找出target的大概位置,也就是target可能在left,right,right+1这三个位置,然后再仔细判断target的位置。
本题解析所用的编程语言:c++
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param labels int整型vector
* @param target int整型
* @return int整型
*/
int searchInsert(vector<int>& labels, int target) {
// write code here
int left = 0, right = labels.size() - 1;
while (left < right)
{
if (right - left == 1)
break;
int mid = (left + right) / 2;
if (labels[mid] < target)
left = mid;
else if (labels[mid] > target)
right = mid;
else
return mid;
}
if (labels[right] < target && right == labels.size() - 1)
return right + 1;
else if (labels[right] >= target && labels[left] < target)
return right;
else
return left;
}
};

查看10道真题和解析