福州高端网站建设服务网络公司建设银行软件官方网站

news/2025/10/1 21:32:40/文章来源:
福州高端网站建设服务网络公司,建设银行软件官方网站,厦门住房建设局网站,做网站吸引客户目录 56. 合并区间 方法1#xff1a;fff 看方法2#xff1a;fff优化版 方法3#xff1a; 738.单调递增的数字 968.监控二叉树#xff08;贪心二叉树#xff09; 56. 合并区间 判断重叠区间问题#xff0c;与452和435是一个套路 方法1#xff1a;fff 看方法2fff 看方法2fff优化版 方法3 738.单调递增的数字 968.监控二叉树贪心二叉树 56. 合并区间 判断重叠区间问题与452和435是一个套路 方法1fff 看方法2fff优化版 使用currentInterval来追踪当前合并的区间而不是在原数组上修改值。每当找到一个不重叠的区间时将currentInterval添加到result并开始一个新的currentInterval。 class Solution {public int[][] merge(int[][] intervals) {// 方法1fff // if (intervals.length 1){ // return intervals; // } // Arrays.sort(intervals,(a,b)-Integer.compare(a[0],b[0])); // int[][] result new int[intervals.length][]; // int row 0; // for (int i 0; i intervals.length - 1; i) { // if (intervals[i 1][0] intervals[i][1]){ // intervals[i 1][0] Math.min(intervals[i][0],intervals[i 1][0]); // intervals[i 1][1] Math.max(intervals[i][1],intervals[i 1][1]); // } else { // result[row] intervals[i]; // } // } // result[row] intervals[intervals.length - 1]; // int[][] res new int[row1][]; // int i 0; // for (int[] r : result){ // if (r null){ // break; // } // res[i] r; // } // return res;// 方法2fff优化版if (intervals.length 1){return intervals;}// 排序的时间复杂度是O(n log n), n是intervals数组的长度。Arrays.sort(intervals,(a,b)-Integer.compare(a[0],b[0]));Listint[] result new LinkedList();int[] currentInterval intervals[0]; // 使用currentInterval来追踪当前合并的区间而不是在原数组上修改值。for (int i 1; i intervals.length ; i) {if (intervals[i][0] currentInterval[1]){// 合并currentInterval[1] Math.max(currentInterval[1], intervals[i][1]);} else {result.add(currentInterval);currentInterval intervals[i];}}result.add(currentInterval);return result.toArray(new int[result.size()][]);} } 方法3 看方法2或者3都可以复杂度是一样的。都挺好的。 代码结构方法3实现直接使用LinkedListint[]的getLast()和removeLast()来获取和更新最后一个合并区间代码更加简洁且避免了在原数组上修改数据。操作顺序方法3实现中每次更新最后一个区间的值时先移除再添加这样减少了代码复杂性而方法2实现会在原数组上更新代码稍显繁琐。 class Solution {public int[][] merge(int[][] intervals) {//方法3LinkedListint[] res new LinkedList();Arrays.sort(intervals, (a, b) - Integer.compare(a[0], b[0]));res.add(intervals[0]);for (int i 1; i intervals.length; i) {if (intervals[i][0] res.getLast()[1]) {int start res.getLast()[0];int end Math.max(intervals[i][1], res.getLast()[1]);res.removeLast();res.add(new int[]{start, end});} else {res.add(intervals[i]);}}return res.toArray(new int[res.size()][]);}} 738.单调递增的数字 思路 例如98一旦出现strNum[i - 1] strNum[i]的情况非单调递增首先想让strNum[i - 1]减一strNum[i]赋值9这样这个整数就是89。 并且需要注意用一个flag来标记从哪里开始赋值9。后面的都要赋值9。 遍历顺序从后向前遍历 从前向后遍历的话遇到strNum[i - 1] strNum[i]的情况让strNum[i - 1]减一但此时如果strNum[i - 1]减一了可能又小于strNum[i - 2]。 这么说有点抽象举个例子数字332从前向后遍历的话那么就把变成了329此时2又小于了第一位的3了真正的结果应该是299。 那么从后向前遍历就可以重复利用上次比较得出的结果了从后向前遍历332的数值变化为332 - 329 - 299 class Solution {public int monotoneIncreasingDigits(int n) {if (n 10) {return n;}String str n ;char[] ch str.toCharArray();int index ch.length;for (int i ch.length - 1; i 0; i--) {if (ch[i] ch[i-1]) {index i;ch[index-1]--;}}for (int i index; i ch.length; i) {ch[i] 9;}String res new String(ch);return Integer.parseInt(res);}} 968.监控二叉树贪心二叉树 思路 摄像头可以覆盖上中下三层如果把摄像头放在叶子节点上就浪费的一层的覆盖。 所以把摄像头放在叶子节点的父节点位置才能充分利用摄像头的覆盖面积。 那么有同学可能问了为什么不从头结点开始看起呢为啥要从叶子节点看呢 因为头结点放不放摄像头也就省下一个摄像头 叶子节点放不放摄像头省下了的摄像头数量是指数阶别的。 所以我们要从下往上看局部最优让叶子节点的父节点安摄像头所用摄像头最少整体最优全部摄像头数量所用最少 大体思路就是从低到上先给叶子节点父节点放个摄像头然后隔两个节点放一个摄像头直至到二叉树头结点。 此时这道题目还有两个难点 二叉树的遍历 后序遍历如何隔两个节点放一个摄像头 如何隔两个节点放一个摄像头 此时需要状态转移的公式大家不要和动态的状态转移公式混到一起本题状态转移没有择优的过程就是单纯的状态转移 来看看这个状态应该如何转移先来看看每个节点可能有几种状态分别有三个数字来表示 0该节点无覆盖1本节点有摄像头2本节点有覆盖 空节点的状态只能是有覆盖这样就可以在叶子节点的父节点放摄像头了 单层逻辑处理。 主要有如下四类情况 情况1左右节点都有覆盖 左孩子有覆盖右孩子有覆盖那么此时中间节点应该就是无覆盖的状态了。 情况2左右节点至少有一个无覆盖的情况 此时摄像头的数量要加一并且return 1代表中间节点放摄像头。 情况3左右节点至少有一个有摄像头 如果是以下情况其实就是 左右孩子节点有一个有摄像头了那么其父节点就应该是2覆盖的状态 left 1 right 2 左节点有摄像头右节点有覆盖left 2 right 1 左节点有覆盖右节点有摄像头left 1 right 1 左右节点都有摄像头 情况4头结点没有覆盖 以上都处理完了递归结束之后可能头结点 还有一个无覆盖的情况如图 所以递归结束之后还要判断根节点如果没有覆盖result class Solution {int res 0;public int minCameraCover(TreeNode root) {// 对根节点的状态做检验,防止根节点是无覆盖状态if (minCame2(root) 0) {res;}return res;}/*** 节点的状态值* 0 表示 无覆盖* 1 表示 有摄像头* 2 表示 有覆盖* 后序遍历根据左右节点的情况,来判读 自己的状态*/// 流程清晰版public int minCame(TreeNode root) {if (root null) {// 空节点默认为 有覆盖状态避免在叶子节点上放摄像头return 2;}int left minCame(root.left);int right minCame(root.right);//中逻辑处理// 如果左右节点都覆盖了的话, 那么本节点的状态就应该是无覆盖,没有摄像头if (left 2 right 2) {return 0;} else if (left 0 || right 0) {// 左右节点是无覆盖状态,那 根节点此时应该放一个摄像头res;return 1;} else {//左右节点至少存在 1个摄像头,那么本节点就是处于被覆盖状态return 2;}}// 简化分支版本public int minCame2(TreeNode root) {if (root null) {return 2;}int left minCame2(root.left);int right minCame2(root.right);// 有任意一个子节点为无覆盖就需要当前节点放相机if (left 0 || right 0) {res;return 1;}if (left 2 right 2) { // 左右子树都是有覆盖那么此时返回无覆盖return 0;}return 2; // 剩下情况就是左右子树有可能为 1 有摄像头即当前节点被监控}} 第三十一天的总算是结束了直冲Day32

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/924297.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20251001 之所思 - 人生如梦

20251001 之所思 今年的生日恰好遇到了国庆,猛然间发现这也是自己最后以三开头的生日了;明年的今天就40岁了,有点恍惚,感觉最近的五年过的太快了,仿佛被偷走了一样 ...今天起的很早,希望自己接下来的一年都能早起…

app界面设计欣赏网站无锡高端网站设计制作

0. 简介 关于车辆的全景环视系统网上已经有很多的资料,然而几乎没有可供参考的代码,这一点对入门的新人来说非常不友好。全景环视系统,又称AVM。在自动驾驶领域,AVM属于自动泊车系统的一部分,是一种实用性极高、可大幅…

湘潭网站建设开发163企业邮箱服务器怎么设置

在产品的设计及生产过程中,经常会出现设计变更、工艺变更、制程调整、非计划停线及转产、转线等“变化”。 如何确保这些“变化”不影响产品后续的生产品质?这就需要在作业准备验证、停产后验证阶段,进行不能缺少的重要环节——“首件检验”。…

平面设计工作室网站专业的网页设计和网站建设公司

web压力测试工具webbench介绍 webbench最多可以模拟3万个并发连接去测试网站的负载能力,并发能力比较高,可以测试https及动态静态页面。 核心原理 父进程fork若干个子进程,每个子进程在用户要求时间或默认的时间内对目标web循环发出实际访问…

优必选 —— 人形机器人 —— 二次开发

优必选 —— 人形机器人 —— 二次开发本博客是博主个人学习时的一些记录,不保证是为原创,个别文章加入了转载的源地址,还有个别文章是汇总网上多份资料所成,在这之中也必有疏漏未加标注处,如有侵权请与博主联系。…

dns看国外网站建立免费个人网站

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 >出处: >https://www.fangzhipeng.com > 本文出自[方志朋的博客](http://blog.csdn.net/forezp) 本文为转载文章&…

GNS3环境下静态路由配置实例与分析(管理距离、度量值) - 教程

GNS3环境下静态路由配置实例与分析(管理距离、度量值) - 教程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Co…

网站积分的作用京东app官网下载

目录 写在开头1. 电商平台流量概览1.1 流量来源的分类1.2 各流量来源的特性与价值 2. 流量来源的数据分析方法2.1 流量数据收集与整理2.2 流量质量评估指标2.3 流量转化路径分析 3. 流量来源优化策略3.1 提升自然搜索流量的SEO策略关键词优化内容优化技术优化示例:在…

ppt做杂志模板下载网站有哪些如何使用阿里云服务器建设网站

一、背景 应用持续访问又大又热的key,会造成Redis实例CPU高、流量被打满、数据在内存积压,甚至导致实例达到配额限制被oom-kill。在异步调用、pipeline、mget等批量调用场景比较常见。 大key分为两种情况 集合元素多且全量获取集合数据:命…

两级页表

单级页表存在什么问题,如何解决 问题一:页表必须连续存放,因此当页表很大时,需要占用更多个连续的页框 解决方法:为离散分配的页表再建立一张页表,称为页目录表(套娃) 问题二:进程在一段时间内只需要访问几个…

酒店网站建设目标网站建设 科目

目录 LeetCode之路——232. 用栈实现队列 分析: LeetCode之路——225. 用队列实现栈 分析: 栈(Stack)和队列(Queue)是两种基本的数据结构,它们在计算机科学中用于不同的目的。以下是它们的定…

复健。(10月,OI)

1 IAMOI 击倒了我。 P14113 [IAMOI R4] 彻底怒了 我草,P14113 彻底怒了。P14113 指出了最核心的矛盾点:如果你没有清空 cur 时忘记再加入处理的字符,怎么可能无法通过该题?这确实是我的严重错误。我需要彻底承认我…

免费字体设计网站邢台网站建设多少钱

做了很多种方法 1: 线程 thread的方法 2: backGroundWorker的方法 3: 自定义线程类 4: 做一个进度条的窗体 通过自定义设置做(最方便快捷) public partial class waitingProcessbar : Form{public waitin…

深圳凌 网站开发北京网站建设技术托管

package com.lbj.javase23; import java.io.*;public class ExceptionTest04 {public static void main(String[] args) throws FileNotFoundException{//使用throws处理异常不是真正处理异常而是推卸责任,谁调用就上抛给谁//上面的m1方法如果出现了异常&#xff0c…

实用指南:自动驾驶中的传感器技术55——USS(1)

实用指南:自动驾驶中的传感器技术55——USS(1)pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas",…

市场交易反心理特征之三:日内假反转

过于惧怕大资金某一日的出货规模,而没注意大资金的后续意图 案例:2017年9月30日,10月23日和11月3日,京东方A。2017年9月30日,京东方A 2017年10月23日,京东方A2017年11月3日,京东方A 情况描述:在主力大出货后几…

网页端如何 打开百度高德腾讯地图导航

网页端如何 打开百度高德腾讯地图导航 <!DOCTYPE html> <html lang="en" style="font-size: 48px;"><head> <meta http-equiv="content-type" content="text…

完整教程:Coze源码分析-资源库-编辑插件-后端源码-IDL/API/应用服务层

完整教程:Coze源码分析-资源库-编辑插件-后端源码-IDL/API/应用服务层2025-10-01 21:04 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: aut…

网站建设中文百wordpress 网站播放器插件

WX-CSQX12 随着空气污染问题的日益严重&#xff0c;大气环境监测设备成为了我们生活中不可或缺的一部分。而一体化的大气环境监测设备&#xff0c;更是为我们的环境保护工作带来了更多的便利和效益。 一体化大气环境监测设备是一种集成了多种功能于一体的环保设备&#xff0c;…

Linux 中awk命令如何统计每行指定字符出现的次数

001、[root@localhost test]# ls a.txt [root@localhost test]# cat a.txt ## 测试数据 0aa1 0AA2 03 04 05 06 07 08 09 10 1a1 12 [root@localhost test]# awk {a = gsub(&qu…