题解 | #二分查找-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
        int size=nums.size();
        if(size==0){
            return -1;
        }
        //取数组中的长度-1,二分法右边的元素
        int num=size-1;
        //二分法左边的元素
        int p=0;
	   //左右两数的中间的位置
        int mid;
	   //循环条件当左位置小于右位置
        while(p<=num){
        mid=(p+num)/2;
		//中间位置等于所求
        if(nums[mid]==target){
            return mid;
        }
		//当位置元素小于所求左元素向右移
        if(nums[mid]<target){
          p=mid+1;  
        }
		  //当位置元素大于所求左元素向左移
        else{
          num=mid-1;
        }
        }
	  //如果没有找到返回-1
        return -1;
    }
};

全部评论

相关推荐

07-03 11:02
中山大学 C++
字节刚oc,但距离九月秋招很近了有两段互联网实习,非腾讯字节。不敢赌转正,现在在纠结去还是不去如果实习俩月离职会有什么后果吗
阿城我会做到的:不去后悔一辈子,能否转正取决于ld的态度,只要他不卡,答辩就是走流程,个人觉得可以冲一把
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-01 12:22
点赞 评论 收藏
分享
06-17 21:57
门头沟学院 Java
白友:噗嗤,我发现有些人事就爱发这些,明明已读不回就行了,就是要恶心人
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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