力扣 704. 二分查找
创始人
2024-03-06 17:23:50

1.题目:

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

2.示例:

输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4
输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1

3.自己实现:

class Solution {public int search(int[] nums, int target) {int y =0;for(int i =0;i

4.优质写法:

总体模板就是先找到中间的数,与目标相比,如果不符合,直接可以砍去一半,在剩下的一半数组里面找

目标数,同理,如果没找到继续砍去剩余一半的一半.这才符合二分寻找

class Solution {public int search(int[] nums, int target) {//nums.length -1 获取下标int left =0; int right = nums.length -1;while(left<=right){//这里不可以简化为left+right,是因为left和right相加可能会超过int最大值,溢出int mid = left+(right - left)/2;if(nums[mid]==target){return mid;//如果中间的数大于目标,那说明target在mid的左侧,那么需要把右侧去掉,也就是right缩小,已经判断过target小于mid 所以right = mid -1 }else if(nums[mid]>target){right = mid -1;//如果中间数小于target,那么说明target在mid的右侧,数组越靠右越大,所以要把mid左侧删掉left = mid 但是已经判断过mid小于target 所以 left = mid + 1;}else{left = mid +1;}}return -1;}
}

相关内容

热门资讯

埃及塞得港省发生车祸致18人丧... 转自:新华网  新华社开罗2月19日电(记者徐皓夫 姚兵)埃及东北部塞得港省19日发生一起严重交通事...
特朗普会见印尼总统普拉博沃签经...   白宫发表声明称,美国总统特朗普周四在华盛顿特区会见了印尼总统普拉博沃·苏比延多。  两位领导人签...
纽约叫停无人驾驶出租车扩张计划   Waymo将其自动驾驶出租车引入纽约州的重大机会暂时受挫。  纽约州州长凯西·霍楚尔撤回了一项提...
AI技术突破与行业竞争加剧,字... 经济观察网 近一周(2026年2月13日至2月19日),互联网科技领域热点集中在AI技术突破、企业战...
莫霍克工业股价异动,财报与行业... 经济观察网 近期股价波动 根据公开报道,莫霍克工业公司(MHK.US)在2026年1月初出现显著股价...