题解 | #二分查找-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,空间复杂度为常数。

全部评论

相关推荐

爱睡觉的冰箱哥:学历不够啊兄弟,分析师都是9硕✌🏻咱搞不过他们滴
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务