33/81搜索旋转排序数组

假设按照升序排序的数组在预先未知的某个点上进行了旋转。

( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

思路:

  • 设置左右指针开始进入二分循环
  • 判断中间的数是否为target,否则通过比较nums[mid] < nums[right]确定是右边有序还是左边有序,从而通过有序的那部分判断target的是否属于该部分,并以此调整左右指针。

注意包含边界与target的比较,如nums[left] <= target

// len = 0情况
if (nums.length == 0) return -1; // 左右指针
int left = 0, right = nums.length - 1; // 二分循环
while (right >= left){
int mid = left + (right - left) / 2;
if (nums[mid] == target) return mid;
else if (nums[mid] < nums[right]){
if (nums[mid] < target && nums[right] >= target) left = mid + 1;
else right = mid - 1;
}
else {
if (nums[left] <= target && nums[mid] > target) right = mid - 1;
else left = mid + 1;
}
// 81 中可以有重复值,就会出现来面两种情况,[3 1 1] 和 [1 1 3 1],中间值等于最右值,3既可以在左边又可以在右边
// 要添加nums[mid] == nums[right]的处理
// else right--;
} // 出了循环,就是没有找到
return -1;

34在排序数组中查找元素的第一个和最后一个位置

在有重复值,且需要返回重复值中的第一个或最后一个时,用下面的二分搜索

while (lo < hi){
int mid = 1 + lo + (hi - lo) / 2; // 找最后一个时用,+1为了让mid能进一,找第一个不用加
if (nums[mid] > target){ // 找第一个时,这里的逻辑相反
hi = mid - 1;
} else {
lo = mid;
}
}

35搜索插入位置

二分搜索,有就返回index,没有就返回left(二分结束后落在第一个比target大的数的位置上)

74搜索二维矩阵

只是二分搜索的二维版本,最大的不同就是除以列数获取层,对列数取模获取列,即matrix[mid / colsNum][mid % colsNum]

if (matrix.length == 0 || matrix[0].length == 0) return false;

int rowsNum = matrix.length, colsNum = matrix[0].length;

if (matrix[0][0] > target || matrix[rowsNum - 1][colsNum - 1] < target) return false;

int low = 0, high = rowsNum * colsNum - 1;

while (low <= high) {
int mid = low + (high - low) / 2;
if (matrix[mid / colsNum][mid % colsNum] < target) low = mid + 1;
else if (matrix[mid / colsNum][mid % colsNum] > target) high = mid - 1;
else return true; }
return false;

300最长上升子序列,354俄罗斯套娃信封问题

354需要w和h都大于才能装下。
输入: envelopes = [[5,4],[6,4],[6,7],[2,3]]
输出: 3
解释: 最多信封的个数为 3, 组合为: [2,3] => [5,4] => [6,7]。

排序规则,w从小到大,w相等时,h从大到小。原因是,w相等时先让h大的加到list中,从而限制后续再有w相同的信封加入进来扩大list.size(w只有大于才能装下小的)。即便h可能太大了,但后续的信封可以把它替换掉,只要它大于倒数第二个,此时增加信封的门槛又降低了。

List<Integer> list = new ArrayList<>();
// 300省略排序,直接遍历
Arrays.sort(envelopes, (arr1, arr2) -> {
if (arr1[0] != arr2[0]) {
return arr1[0] - arr2[0];
} else {
return arr2[1] - arr1[1];
}
}); for (int[] envelope : envelopes) {
int left = 0, right = list.size() - 1, t = envelope[1];
while (left <= right) {
int mid = left + (right - left) / 2;
if (list.get(mid) < t) left = mid + 1;
else if (list.get(mid) > t) right = mid - 1;
else {
left = mid;
break;
}
}
if (left >= list.size()) list.add(t);
else list.set(left, t);
}
return list.size();

leetcode二分查找相关的更多相关文章

  1. leetcode二分查找问题整理

    自从做完leetcode上的三道关于二分查找的题后,我觉得它是比链表找环还恶心的题,首先能写出bugfree代码的人就不多,而且可以有各种变形,适合面试的时候不断挑战面试者,一个程序猿写代码解决问题的 ...

  2. leetcode 二分查找

    https://oj.leetcode.com/problems/search-for-a-range/就是一个二分查找,没事练练手 public class Solution { public in ...

  3. Leetcode 二分查找 Search Insert Position

    本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie Search Insert Position Total Accepted: 14279 T ...

  4. [leetcode]二分查找总结

    Search for a Range 1.最简单的想法,用最普通的二分查找,找到target,然后向左右扩张,大量的重复的target,就会出现O(n)效率. class Solution { pub ...

  5. leetcode 二分查找 Search in Rotated Sorted ArrayII

    Search in Rotated Sorted Array II Total Accepted: 18500 Total Submissions: 59945My Submissions Follo ...

  6. leetcode 二分查找 Search in Rotated Sorted Array

    Search in Rotated Sorted Array Total Accepted: 28132 Total Submissions: 98526My Submissions Suppose ...

  7. LeetCode 二分查找模板 II

    模板 #2: int binarySearch(vector<int>& nums, int target){ if(nums.size() == 0) return -1; in ...

  8. LeetCode 二分查找模板 I

    模板 #1: int binarySearch(vector<int>& nums, int target){ if(nums.size() == 0) return -1; in ...

  9. LeetCode 二分查找模板 III

    模板 #3: int binarySearch(vector<int>& nums, int target){ if (nums.size() == 0) return -1; i ...

随机推荐

  1. POJ 3070 - 快速矩阵幂求斐波纳契数列

    这题并不复杂. 设$A=\begin{pmatrix} 1 & 1 \\ 1 & 0 \end{pmatrix}$ 由题中公式: $\begin{pmatrix}f(n+1) & ...

  2. 数组的复制 --System.arraycopy()

    import java.util.Arrays; public class HellowWorld { public static void main(String[] argv ) { int[] ...

  3. https webservice通讯 参考网址 http://blog.csdn.net/small____fish/article/details/8214938

    一.生成密钥库和证书可参考以下密钥生成脚本,根据实际情况做必要的修改,其中需要注意的是:服务端的密钥库参数“CN”必须与服务端的IP地址相同,否则会报错,客户端的任意. 1.生成服务器证书库keyto ...

  4. P1886 滑动窗口&&P1440 求m区间内的最小值

    声明:下面这两个题就不要暴力了,学一学单调队列吧 推荐博文:https://www.cnblogs.com/tham/p/8038828.html 单调队列入门题 P1440 求m区间内的最小值 题目 ...

  5. HDU 1465(错排公式)

    不容易系列之一 题意: 一个人要寄n个信封,结果装错了.信纸的编号为1到n,信封的编号为1到n,信纸的编号不能和信封的编号一样,全都不能一样. 思路:错排公式. D(n)表示n件信封装错的所有的情况. ...

  6. PHP基础库及扩展库安装

    一.安装PHP所需的lib库(基础库): 1.yum install zlib-devel libxml2-devel libjpey-devel libjpeg-turbo-devel libico ...

  7. gcc和gdb的基本操作

    gcc和gdb yum 在线安装软件,使用阿里云镜像站,OPSX 选择你安装的系统 点帮助 查看配置命令行 yum --list | grep gdb #查找要安装的软件 yum install -y ...

  8. 从CSV文件中读取jpg图片的URL地址并多线程批量下载

    很多时候,我们的网站上传图片时并没有根据内容进行文件夹分类,甚至会直接存储到阿里云的OSS或是七牛云等云存储上.这样,当我们需要打包图片时,就需要从数据库找寻分类图片,通过CURL进行下载.我最近刚刚 ...

  9. C#学习笔记_10_设计模式&继承&多态

    10_设计模式&继承&多态 设计模式 由前人总结的用来解决特定问题的解决方案 单例模式 在一个项目的不同模块中获取对象,获取到的是同一个对象 代码 继承 概念:如果多个类中具有相同的字 ...

  10. Django REST framework - 解析器和渲染器

    目录 Django REST framework - 解析器和渲染器 解析器 Django中的数据解析 DRF中的解析器 渲染器 Django REST framework - 解析器和渲染器 解析器 ...