编程语言
首页 > 编程语言> > 算法题:704二分查找

算法题:704二分查找

作者:互联网

很长时间没写算法题了,从今天开始慢慢的复习一下。

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target  ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/binary-search
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

public class Solution {
    public int search(int[] nums, int target) {


        int left = 0, right = nums.length - 1;
        if (target < nums[left] || target > nums[right]) return -1;

        int mid = (left + right) / 2;
        while (left<=right) {
            if (target < nums[mid]) right = mid - 1;
            else if (target > nums[mid]) left = mid + 1;

            mid = (left + right) / 2;
            if(nums[mid]==target) return mid;
        }
        return -1;
    }
}

还行,很久没写算法题,第一次写就写出来了,没有错误,没有卡壳。希望以后面试遇到了也能这种状态写出来

 

标签:二分,right,target,nums,704,mid,int,查找,left
来源: https://www.cnblogs.com/wyw123456/p/15778083.html