LeetCode---Binary Search
**475. Heaters
思路:每趟循环查找离房子最近的热水器,计算距离,最后取最大距离
public int findRadius(int[] houses, int[] heaters) {
Arrays.sort(houses);
Arrays.sort(heaters);
int j = 0;
int res = 0;
for(int i = 0; i < houses.length; i++){
//找离house[i]最近的heater
while(j < heaters.length - 1 && heaters[j] + heaters[j + 1] <= 2 * houses[i]){
j++;
}
res = Math.max(res,Math.abs(heaters[j] - houses[i]));
}
return res;
}
**410. Split Array Largest Sum
思路:结果一定在最大值和总和之间,因此在这两个数之间用二分查找;看中间值能不能符合区间个数
public int splitArray(int[] nums, int m) {
int max = 0;
int sum = 0;
for(int i = 0; i < nums.length; i++){
max = Math.max(max,nums[i]);
sum += nums[i];
}
int i = max;
int j = sum;
while(i <= j){
int d = i + (j - i) / 2;
if(isValid(nums,m,d)) j = d - 1;
else i = d + 1;
}
return i;
}
public boolean isValid(int[] nums,int m,int d){
int count = 1;
int total = 0;
for(int i = 0; i < nums.length; i++){
total += nums[i];
if(total > d){
total = nums[i];
count++;
if(count > m) return false;
}
}
return true;
}
**354. Russian Doll Envelopes
思路:将区间按第一个数升序,第二个数降序排列,只需要计算第二个数的最长递增序列个数即可,注意Arrays.sort()的自定义排序的使用,即第300题
public int maxEnvelopes(int[][] envelopes) {
if(envelopes.length == 0 || envelopes[0].length == 0) return 0;
Arrays.sort(envelopes,new Comparator<int[]>(){
public int compare(int[] a,int[] b){
if(a[0] == b[0]){
return b[1] - a[1];
}
else{
return a[0] - b[0];
}
}
});
int[] dp = new int[envelopes.length];
for(int i = 0; i < dp.length; i++) dp[i] = 1;
for(int i = 1; i < envelopes.length; i++){
for(int j = 0; j < i; j++){
if(envelopes[i][1] > envelopes[j][1]) dp[i] = Math.max(dp[i],dp[j] + 1);
}
}
int res = 0;
for(int k : dp){
res = Math.max(k,res);
}
return res;
}
总结
278. First Bad Version:经典二分查找,属于查找临界点,注意最终终止索引
374. Guess Number Higher or Lower:经典二分查找,属于查找某个数
441. Arranging Coins:二分查找,属于查找临界点,注意最终终止索引
367. Valid Perfect Square:二分查找,属于查找某个数
240. Search a 2D Matrix II:从右上角开始查找,小则往下,大则往左
378. Kth Smallest Element in a Sorted Matrix:将matrix放在PriorityQueue中实现排序
392. Is Subsequence:按照s的顺序在t中查找,用计数器计数,等于s.length()则返回true
69. Sqrt(x):二分查找,两个临界点m和m + 1,考虑所有区间的情况即可
训练
300. Longest Increasing Subsequence:dp中的元素表示当前索引值为序列最后一个数时的长度
275. H-Index II:属于查找临界点,注意最终终止索引
**436. Find Right Interval:用TreeMap,注意ceilingEntry()的使用
50. Pow(x, n):递归但是要考虑减少栈帧,还有边界问题
174. Dungeon Game:构造二维数组存每个格子所需最小体力,从终点开始一次往前计算所需最小体力,先计算边界
提示
1.直接查找某个数直接二分查找i <= j,并且最终一定能找到
2.若是找某个临界点,也直接i <= j,只不过要想清楚最终终止索引的位置,相邻数中点一定是较小数,并且一定在临界点左边或就是临界点减小了范围
3.若查找过程中判定条件会越界,则将int转化为long
LeetCode---Binary Search的更多相关文章
- [LeetCode] Binary Search 二分搜索法
Given a sorted (in ascending order) integer array nums of n elements and a target value, write a fun ...
- LeetCode Binary Search All In One
LeetCode Binary Search All In One Binary Search 二分查找算法 https://leetcode-cn.com/problems/binary-searc ...
- LeetCode & Binary Search 解题模版
LeetCode & Binary Search 解题模版 In computer science, binary search, also known as half-interval se ...
- [LeetCode] Binary Search Tree Iterator 二叉搜索树迭代器
Implement an iterator over a binary search tree (BST). Your iterator will be initialized with the ro ...
- LeetCode Binary Search Tree Iterator
原题链接在这里:https://leetcode.com/problems/binary-search-tree-iterator/ Implement an iterator over a bina ...
- [Leetcode] Binary search -- 475. Heaters
Winter is coming! Your first job during the contest is to design a standard heater with fixed warm r ...
- 153. Find Minimum in Rotated Sorted Array(leetcode, binary search)
https://leetcode.com/problems/find-minimum-in-rotated-sorted-array/description/ leetcode 的题目,binary ...
- [Leetcode] Binary search, Divide and conquer--240. Search a 2D Matrix II
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- [Leetcode] Binary search, DP--300. Longest Increasing Subsequence
Given an unsorted array of integers, find the length of longest increasing subsequence. For example, ...
- LeetCode: Binary Search Tree Iterator 解题报告
Binary Search Tree Iterator Implement an iterator over a binary search tree (BST). Your iterator wil ...
随机推荐
- Linux下使用NMON监控、分析系统性能
一.下载nmon. 根据CPU的类型选择下载相应的版本:http://nmon.sourceforge.net/pmwiki.php?n=Site.Downloadwget http://source ...
- (l老陈-小石头)典型用户、用户故事、用例图
一.典型用户 老陈 小石头 二.用户故事 老陈:作为一个家长,我希望能利用软件在电脑上储存一些数学题目,以便在繁忙的工作中也能帮助到孩子提高数学. 小石头:作为一个小学二年级的小学生,我希望能利用软件 ...
- NPOI 数据导入导出
{ //数据导入 OpenFileDialog open = new OpenFileDialog(); open.Filter = "Excle文件|*.xls"; open.T ...
- Android编译系统参考手册
build/core/clear_vars.mk Clear out values of all variables used by rule templates 清除LOCAL变量,每个模块的And ...
- MySql使用游标Cursor循环(While)更新数据
#要修改的变量 DECLARE var_ID VARCHAR(50) DEFAULT ''; #需要修改的数据的数量 DECLARE var_UpdateCount INT; #当前循环次数 DECL ...
- SSH整合!!!!不会的赶紧来
说到SSH也就是Spring,struts2,Hibernate三大框架那么咱们话不多说开始搭建吧 首先我们这个项目的目的是应用三大框架将一个商品的信息保存到数据库中. 第一步就是创建Web项目,引入 ...
- Kmeans++算是DONet实现
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...
- 关于thinkphp中的G方法使用
最近在研究thinkphp框架发现其中有好多东西很值得借鉴今天看了一下函数G()很适合调试出页面执行的时间和使用的内存情况具体的代码如下 <?php /** * 记录和统计时间(微秒)和内存使用 ...
- Something about Wake-sleep
DBN可以看做是n个RBM串联组成,是一个多层神经网络. 多层的好处是可以用较少的参数表示复杂的函数. 而一些传统的training算法如BP算法,处理多层网络时,效果就不是很理想.
- 转:Task任务调度实现生产者消费者模式 (个人理解后文)
纯属个人愚见.欢迎加入反驳(PiDou). 1.前文大致就是,利用Queue配置的一个TaskFactory任务调度器.实现生产者消费者模式的例子..首先我就试了 第一种 FIFO(先进先出)的配置. ...