一个网站如何做seo优化,被墙网站怎么做301跳转,北京市政建设集团有限公司,中科 网站会员注册系统建设代码随想录算法训练营第三十四天 | 860.柠檬水找零 、 406.根据身高重建队列、452. 用最少数量的箭引爆气球
860.柠檬水找零
题目链接#xff1a;860. 柠檬水找零 - 力扣#xff08;LeetCode#xff09;
class Solution {public boolean lemonadeChange(int[] bills) {//…代码随想录算法训练营第三十四天 | 860.柠檬水找零 、 406.根据身高重建队列、452. 用最少数量的箭引爆气球
860.柠檬水找零
题目链接860. 柠檬水找零 - 力扣LeetCode
class Solution {public boolean lemonadeChange(int[] bills) {// 记录五元、十元、二十元面额纸币的张数int fives 0, tens 0, tws 0; for(int bill : bills) {// 收到五元无需找零if(bill 5) fives;// 收到十元只能找零五元没有五元就直接返回falseif(bill 10) {if(fives 0) return false;fives--;tens;}// 收到二十元此时有两种选择// 1. 找零 10 5// 2. 找零 5 * 3// 因为美元10只能给账单20找零而美元5可以给账单10和账单20找零美元5更万能// 所以局部最优遇到账单20优先消耗美元10完成本次找零。全局最优完成全部账单的找零。if(bill 20) {if(fives 0 tens 0) {tens--;fives--;tws;} else if(fives 3) {fives - 3;tws;} else {return false;}}}return true;}
}406.根据身高重建队列
题目链接406. 根据身高重建队列 - 力扣LeetCode
本题先理解思路
class Solution {public int[][] reconstructQueue(int[][] people) {// 身高从大到小排身高相同k小的站前面Arrays.sort(people, (a, b) - {if (a[0] b[0]) return a[1] - b[1]; // a - b 是升序排列故在a[0] b[0]的狀況下會根據k值升序排列return b[0] - a[0]; //b - a 是降序排列在a[0] ! b[0]的狀況會根據h值降序排列});LinkedListint[] que new LinkedList();for (int[] p : people) {que.add(p[1],p); //Linkedlist.add(index, value)會將value插入到指定index裡。}return que.toArray(new int[people.length][]);}
}452. 用最少数量的箭引爆气球
题目链接452. 用最少数量的箭引爆气球 - 力扣LeetCode
class Solution {public int findMinArrowShots(int[][] points) {// 根据气球直径的开始坐标从小到大排序// 使用Integer内置比较方法不会溢出Arrays.sort(points, (a, b) - Integer.compare(a[0], b[0]));int count 1; // points 不为空至少需要一支箭for (int i 1; i points.length; i) {if (points[i][0] points[i - 1][1]) { // 气球i和气球i-1不挨着注意这里不是count; // 需要一支箭} else { // 气球i和气球i-1挨着points[i][1] Math.min(points[i][1], points[i - 1][1]); // 更新重叠气球最小右边界// 因为两个气球挨着而且前一个肯定已经用了一只箭了这里直接更新重叠的// 为了使后续的不考虑当前的气球将当前气球右边界更新为挨在一起可能不止这两个气球中的最小值}}return count;}
}