目录
一、简单题 704. 二分查找
1.1题目描述
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。(假设无重复元素)
1.2解题思路
- 由排序好、查找直接锁定二分查找算法(也叫折半法,在每次判断后能够将搜索范围减少一半)
二分算法图解:
每次搜索范围为 [left,right] ,判断中间值 mid=(left+right)/2 是否为搜索目标,若目标大于中间值 if(target>nums[mid]) 则目标在mid右边,即为[mid+1,right]于是将 left=mid+1 ;若等于,则直接输出即可;若小于同理把 right=mid-1 。
由于判断结束条件为left <= right,而left >= 0, right <= nums.lenght - 1;因此就算有mid+1,mid-1也不会超出0~length-1的范围。
具体图示如下:
二分算法Java实现:
class Solution {
public int search(int[] nums, int target) {
int left=0,right=nums.length-1;
while(left<=right){
//int mid=(left+right)/2;下面的方法防止计算溢出
int mid = left + (right - left) / 2;
if(target>nums[mid]){
left=mid+1;
}
else if(target==nums[mid]){
return mid;
}
else{//target<nums[mids]
right=mid-1;
}
}
return -1;
}
}
二、中等题 702. 搜索长度未知的有序数组
2.1题目描述
给定一个升序整数数组,写一个函数搜索 nums 中数字 target。如果 target 存在,返回它的下标,否则返回 -1。注意,这个数组的大小是未知的。你只可以通过 ArrayReader 接口访问这个数组,ArrayReader.get(k) 返回数组中第 k 个元素(下标从 0 开始)。
你可以认为数组中所有的整数都小于 10000。如果你访问数组越界,ArrayReader.get 会返回 2147483647。
2.2解题思路
- 由排序好、查找直接锁定二分查找算法(也叫折半法,在每次判断后能够将搜索范围减少一半),但是和上一题不同的是,这次无法确定右边界。
由此先确定右边界,先令left=0,right=1,判断target是否大于nums.get(right),若大于,先令left=right+1,然后直接倍增right*=2,若小于等于则取得边界[left,right];确定边界后,再使用之前的思路即可。
边界确定算法图解:
题解Java实现:
class Solution {
public int search(ArrayReader reader, int target) {
int left = 0;
int right = 1;
while (target > reader.get(right)) {
left = right+1;
right = right * 2;
}
while(left<=right){
//int mid=(left+right)/2;下面的方法防止计算溢出
int mid = left + (right - left) / 2;
if(target>reader.get(mid)){
left=mid+1;
}
else if(target==reader.get(mid)){
return mid;
}
else{//target<reader.get(mid)
right=mid-1;
}
}
return -1;
}
}
结尾
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems
关注作者,每日带你刷题,从简单的算法题了解最常用的算法技能(算法题解双日一更)
每日同类型两道算法题——简单到进阶,让你不知不觉成为无情的刷题机器