声明:
模板的内容来源于力扣的探索章节,加上了自己的理解后的修改以及注释
0、介绍
二分查找是一种在每次比较之后将查找空间一分为二
的算法。每次需要查找集合中的索引或元素时,都应该考虑二分查找。如果集合是无序的,我们可以总是在应用二分查找之前先对其进行排序
。
二分查找一般由三个主要部分组成:
- 预处理 —— 如果集合未排序,则进行排序。
- 二分查找 —— 使用循环或递归在每次比较后将查找空间划分为两半。
- 后处理 —— 在剩余空间中确定可行的候选者。
先来看一个最基本的二分查找题目:
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的
target,如果目标值存在返回下标,否则返回 -1。示例 1:
输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4 解释: 9 出现在 nums 中并且下标为 4
示例 2:
输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1 解释: 2 不存在 nums 中因此返回 -1
提示:
你可以假设 nums 中的所有元素是不重复的。
n 将在 [1, 10000]之间。
nums 的每个元素都将在 [-9999, 9999]之间。
我们很容易能写出这样的代码:
class Solution {
public int search(int[] nums, int target) {
int i = 0;
int j = nums.length-1;
while( i<=j ){
int mid = i + (j-i)/2;
if( nums[mid]==target ){
return mid;
}
if( nums[mid]<target ){
i = mid + 1;
}else{
j = mid - 1;
}