算法题: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