很长时间没写算法题了,从今天开始慢慢的复习一下。
给定一个 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; } }
还行,很久没写算法题,第一次写就写出来了,没有错误,没有卡壳。希望以后面试遇到了也能这种状态写出来