题解 | #二分查找-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
	  	//学习笔记之二分法
        //下标为0到N-1,区间范围采用左闭又闭
        int left = 0;
        int right = nums.size()-1;
        while(left <= right)
        {
            //优化中间值取法
            //int middle = (left + right) /2 ;
            //int middle = left + (right - left) / 2;
            int middle = left + ((right - left) >>1);
            if(target > nums[middle])
                left = left + 1; //在右半边,更新左侧区间
            else if(target < nums[middle])
                right = right - 1; //在左半边,更新右侧区间
            else
                return middle;
        }
        return -1;  //没找到返回-1

    }
};

全部评论

相关推荐

2025-11-10 08:05
河北师范大学 Java
用微笑面对困难:你出于礼貌叫了人一声大姐,大姐很欣慰,她真把你当老弟
点赞 评论 收藏
分享
01-04 07:53
门头沟学院 C++
心愿便利贴:工作了以后回头再看待这个问题,从客观的视角来讲是因为每个人对自己的要求不同,学习好的人对自己的要求很高,所以觉得考不好就天塌了,认为自己学习好并且值得一份好工作的人也是一样,找不到符合自己预期的工作肯定也会觉得是侮辱,牛客上有很多名校大学生,肯定会存在这种好学生心态啊,“做题区”从来都不是贬义词,这是大部分普通人赖以生存的路径,这个有什么好嘲讽的,有“好学生心态”没有错,但是不要给自己太大的压力了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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