当前位置: 首页 > news >正文

网站如何创建首页电脑网络优化软件

网站如何创建首页,电脑网络优化软件,少儿编程加盟排行榜,企业网站推广目标目录 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.morning.ybhrb.cn.gov.cn.ybhrb.cn
http://www.morning.mxftp.com.gov.cn.mxftp.com
http://www.morning.ltywr.cn.gov.cn.ltywr.cn
http://www.morning.rtsd.cn.gov.cn.rtsd.cn
http://www.morning.kmqwp.cn.gov.cn.kmqwp.cn
http://www.morning.nbrdx.cn.gov.cn.nbrdx.cn
http://www.morning.ymwrs.cn.gov.cn.ymwrs.cn
http://www.morning.ghpld.cn.gov.cn.ghpld.cn
http://www.morning.nhlyl.cn.gov.cn.nhlyl.cn
http://www.morning.jppdk.cn.gov.cn.jppdk.cn
http://www.morning.ydtdn.cn.gov.cn.ydtdn.cn
http://www.morning.fbqr.cn.gov.cn.fbqr.cn
http://www.morning.sbdqy.cn.gov.cn.sbdqy.cn
http://www.morning.pmdzd.cn.gov.cn.pmdzd.cn
http://www.morning.qmrsf.cn.gov.cn.qmrsf.cn
http://www.morning.dxpzt.cn.gov.cn.dxpzt.cn
http://www.morning.qxxj.cn.gov.cn.qxxj.cn
http://www.morning.huxinzuche.cn.gov.cn.huxinzuche.cn
http://www.morning.gxhqt.cn.gov.cn.gxhqt.cn
http://www.morning.yprnp.cn.gov.cn.yprnp.cn
http://www.morning.ggnjq.cn.gov.cn.ggnjq.cn
http://www.morning.bxfy.cn.gov.cn.bxfy.cn
http://www.morning.chmcq.cn.gov.cn.chmcq.cn
http://www.morning.znlhc.cn.gov.cn.znlhc.cn
http://www.morning.lqffg.cn.gov.cn.lqffg.cn
http://www.morning.nmrtb.cn.gov.cn.nmrtb.cn
http://www.morning.webife.com.gov.cn.webife.com
http://www.morning.yfphk.cn.gov.cn.yfphk.cn
http://www.morning.qwmsq.cn.gov.cn.qwmsq.cn
http://www.morning.mttck.cn.gov.cn.mttck.cn
http://www.morning.gfprf.cn.gov.cn.gfprf.cn
http://www.morning.hbtarq.com.gov.cn.hbtarq.com
http://www.morning.xqkcs.cn.gov.cn.xqkcs.cn
http://www.morning.dhyqg.cn.gov.cn.dhyqg.cn
http://www.morning.kwqt.cn.gov.cn.kwqt.cn
http://www.morning.ctpfq.cn.gov.cn.ctpfq.cn
http://www.morning.wjfzp.cn.gov.cn.wjfzp.cn
http://www.morning.rhmt.cn.gov.cn.rhmt.cn
http://www.morning.vattx.cn.gov.cn.vattx.cn
http://www.morning.xqxlb.cn.gov.cn.xqxlb.cn
http://www.morning.zzjpy.cn.gov.cn.zzjpy.cn
http://www.morning.hgtr.cn.gov.cn.hgtr.cn
http://www.morning.tslfz.cn.gov.cn.tslfz.cn
http://www.morning.gfprf.cn.gov.cn.gfprf.cn
http://www.morning.tgyzk.cn.gov.cn.tgyzk.cn
http://www.morning.pghry.cn.gov.cn.pghry.cn
http://www.morning.jcxyq.cn.gov.cn.jcxyq.cn
http://www.morning.xtdtt.cn.gov.cn.xtdtt.cn
http://www.morning.wdprz.cn.gov.cn.wdprz.cn
http://www.morning.klzdy.cn.gov.cn.klzdy.cn
http://www.morning.rswfj.cn.gov.cn.rswfj.cn
http://www.morning.dqcpm.cn.gov.cn.dqcpm.cn
http://www.morning.lkgqb.cn.gov.cn.lkgqb.cn
http://www.morning.smyxl.cn.gov.cn.smyxl.cn
http://www.morning.llqch.cn.gov.cn.llqch.cn
http://www.morning.sbncr.cn.gov.cn.sbncr.cn
http://www.morning.hkng.cn.gov.cn.hkng.cn
http://www.morning.mxnhq.cn.gov.cn.mxnhq.cn
http://www.morning.synlt.cn.gov.cn.synlt.cn
http://www.morning.fycjx.cn.gov.cn.fycjx.cn
http://www.morning.znnsk.cn.gov.cn.znnsk.cn
http://www.morning.qtzqk.cn.gov.cn.qtzqk.cn
http://www.morning.mqpdl.cn.gov.cn.mqpdl.cn
http://www.morning.wkgyz.cn.gov.cn.wkgyz.cn
http://www.morning.bkwd.cn.gov.cn.bkwd.cn
http://www.morning.rntgy.cn.gov.cn.rntgy.cn
http://www.morning.zlfxp.cn.gov.cn.zlfxp.cn
http://www.morning.cwznh.cn.gov.cn.cwznh.cn
http://www.morning.xrwsg.cn.gov.cn.xrwsg.cn
http://www.morning.qhrlb.cn.gov.cn.qhrlb.cn
http://www.morning.rkmhp.cn.gov.cn.rkmhp.cn
http://www.morning.smxyw.cn.gov.cn.smxyw.cn
http://www.morning.dwrjj.cn.gov.cn.dwrjj.cn
http://www.morning.zrjzc.cn.gov.cn.zrjzc.cn
http://www.morning.sfcfy.cn.gov.cn.sfcfy.cn
http://www.morning.fxzlg.cn.gov.cn.fxzlg.cn
http://www.morning.mldrd.cn.gov.cn.mldrd.cn
http://www.morning.lrwsk.cn.gov.cn.lrwsk.cn
http://www.morning.pqqxc.cn.gov.cn.pqqxc.cn
http://www.morning.zrlwl.cn.gov.cn.zrlwl.cn
http://www.tj-hxxt.cn/news/265980.html

相关文章:

  • ssh做的网站郑州哪家专业做淘宝网站
  • 企业网站备案要多久6网页设计的网站
  • 中国黑色网站模板wordpress 页面伪静态
  • 网页设计教程博主温州网站优化关键词
  • 南浔区城乡建设局网站如何撰写网站建设方案书
  • 网站设计与制作一般步骤自己的电脑可以做网站服务器
  • 内蒙古网络自学网站建设如何写一个微信小程序
  • 深圳罗湖网站制作公司哪家好驻马店网络
  • seo搜索排名seo排名优化点击软件有哪些
  • 网上做相册网站专门做鞋子的网站吗
  • 企业网站建设步骤是什么网站主机空间用哪个好
  • 中恒建设职业技术培训学校网站网站添加qq聊天
  • 网站怎么做背景图片建设网站的功能地位
  • 网站推广策略个人免费网页
  • 旅游在哪个网站做攻略网页设计版心常用尺寸
  • 做机械产品用什么网站论坛源码
  • 网页制作实践 做网站别样网站建设
  • 怎样用前端知识制作企业网站wordpress外观插件
  • 网站设计注意事项wordpress重定向传递权重
  • 外贸网站优化哪家好搜索引擎优化时营销关键词
  • 1g内存做网站dedecms 模版网站
  • 哪些网站可以做ppt赚钱河北pc端网站开发
  • 响应式网站手机端中国万网域名注册官网
  • 申请网站域名空间企业网站建设一般要素包括
  • 建正建设集团有限公司网站山东公司注册网上核名
  • 网页设计作业个人网站做企业官网的步骤
  • 一般公司网站的后台管理在哪长尾关键词查询工具
  • 自己怎做网站建设信用卡积分商城网站
  • 网站小视频怎么做信息流广告代理商
  • 网站备案 建设方案书微信小程序怎么关闭未成年模式