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

澄海网站建设怎么制作网站教程下载

澄海网站建设,怎么制作网站教程下载,漂亮的网页,做网站做生意56 合并区间 给出一个区间的集合&#xff0c;请合并所有重叠的区间。 示例 1: 输入: intervals [[1,3],[2,6],[8,10],[15,18]]输出: [[1,6],[8,10],[15,18]]解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6]. class Solution { public:vector<vector<int>>…

56 合并区间

给出一个区间的集合,请合并所有重叠的区间。

示例 1:

  • 输入: intervals = [[1,3],[2,6],[8,10],[15,18]]
  • 输出: [[1,6],[8,10],[15,18]]
  • 解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
class Solution {
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {vector<vector<int>> result;if (intervals.size() == 0) return result; // 区间集合为空直接返回// 排序的参数使用了lambda表达式sort(intervals.begin(), intervals.end(), [](const vector<int>& a, const vector<int>& b){return a[0] < b[0];});// 第一个区间就可以放进结果集里,后面如果重叠,在result上直接合并result.push_back(intervals[0]); for (int i = 1; i < intervals.size(); i++) {if (result.back()[1] >= intervals[i][0]) { // 发现重叠区间// 合并区间,只更新右边界就好,因为result.back()的左边界一定是最小值,因为我们按照左边界排序的result.back()[1] = max(result.back()[1], intervals[i][1]); } else {result.push_back(intervals[i]); // 区间不重叠 }}return result;}
};

        本题主要技巧是在result数组里面进行重叠操作,而不是在原数组里面进行合并。 

 738 单调递增的数字

给定一个非负整数 N,找出小于或等于 N 的最大的整数,同时这个整数需要满足其各个位数上的数字是单调递增。

(当且仅当每个相邻位数上的数字 x 和 y 满足 x <= y 时,我们称这个整数是单调递增的。)

示例 1:

  • 输入: N = 10
  • 输出: 9

示例 2:

  • 输入: N = 1234
  • 输出: 1234

示例 3:

  • 输入: N = 332
  • 输出: 299

说明: N 是在 [0, 10^9] 范围内的一个整数

本题如果使用暴力解法,从后往前一个数一个数的遍历,一定会超时,所以采用贪心算法:

如果前一个数比后一个数大,就将后一个数变成9,前一个数减1,从后往前遍历即可,同时,在处理变成9的时候不要直接处理,而是利用一个flag标志记录此时的位置,最后flag后面的所有数一起变成9,例如1000,如果不用flag的话,最后两个00是不会变的:

class Solution {
public:int monotoneIncreasingDigits(int N) {string strNum = to_string(N);// flag用来标记赋值9从哪里开始// 设置为这个默认值,为了防止第二个for循环在flag没有被赋值的情况下执行int flag = strNum.size();for (int i = strNum.size() - 1; i > 0; i--) {if (strNum[i - 1] > strNum[i] ) {flag = i;strNum[i - 1]--;}}for (int i = flag; i < strNum.size(); i++) {strNum[i] = '9';}return stoi(strNum);}
};

 968 监控二叉树

给定一个二叉树,我们在树的节点上安装摄像头。

节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。

计算监控树的所有节点所需的最小摄像头数量。

示例 1:

  • 输入:[0,0,null,0,0]
  • 输出:1
  • 解释:如图所示,一台摄像头足以监控所有节点。

示例 2:

  • 输入:[0,0,null,0,null,0,null,null,0]
  • 输出:2
  • 解释:需要至少两个摄像头来监视树的所有节点。 上图显示了摄像头放置的有效位置之一。

提示:

  • 给定树的节点数的范围是 [1, 1000]。
  • 每个节点的值都是 0。

        本题要求的是最少的摄像头,所以尽量让叶子节点的父节点为摄像头,每隔两层安装一个新的摄像头。于是本题采用后序遍历。

        本题分别用数字代表此时的状态:0代表这个点没有被覆盖,1代表本节点有摄像头,2代表本节点被摄像头覆盖。

        一共有四种不同情况:代码如下:

class Solution {
private:int result;int traversal(TreeNode* cur) {// 空节点,该节点有覆盖if (cur == NULL) return 2;int left = traversal(cur->left);    // 左int right = traversal(cur->right);  // 右// 情况1// 左右节点都有覆盖if (left == 2 && right == 2) return 0;// 情况2// left == 0 && right == 0 左右节点无覆盖// left == 1 && right == 0 左节点有摄像头,右节点无覆盖// left == 0 && right == 1 左节点有无覆盖,右节点摄像头// left == 0 && right == 2 左节点无覆盖,右节点覆盖// left == 2 && right == 0 左节点覆盖,右节点无覆盖if (left == 0 || right == 0) {result++;return 1;}// 情况3// left == 1 && right == 2 左节点有摄像头,右节点有覆盖// left == 2 && right == 1 左节点有覆盖,右节点有摄像头// left == 1 && right == 1 左右节点都有摄像头// 其他情况前段代码均已覆盖if (left == 1 || right == 1) return 2;// 以上代码我没有使用else,主要是为了把各个分支条件展现出来,这样代码有助于读者理解// 这个 return -1 逻辑不会走到这里。return -1;}public:int minCameraCover(TreeNode* root) {result = 0;// 情况4if (traversal(root) == 0) { // root 无覆盖result++;}return result;}
};
http://www.yayakq.cn/news/100990/

相关文章:

  • 有哪些好的网站制作公司编程培训网站
  • 青岛昌隆文具网站是哪家公司做的公司网站域名管理
  • 腾冲做兼职的网站谷歌浏览器 安卓下载2023版官网
  • 石家庄市建设网站08 iis创建网站
  • php做简易网站网页制作自学教程
  • wordpress网站重新安装插件网站首页怎么做营业执照链接
  • 网站营销工具logo设计网站免费无水印
  • 如何建立手机网站wordpress怎么添加二级域名
  • 建网站需要编程吗免费开源的建站系统
  • 做网站需要网页嵌套吗app定制开发谈判技巧
  • 贵州百度seo整站优化做品牌 需要做网站吗
  • 静态网站开发工具有哪些区网站建设
  • 网时 网站服务器租赁济南赢动网站建设
  • 多语种外贸网站建设3d动画制作软件中文版
  • 电子商务企业网站的建设react用于做PC网站
  • 网站备案需要什么条件宝塔一键部署wordpress最新版
  • 网站建设的制度电脑培训班
  • 国外获奖网站wordpress自定义tag页面
  • 嘉定网站网站建设深圳网站设计与制作公司
  • 建设通网站是什么网站wordpress怎么还原
  • 网站后台可以备份吗wordpress 目录 导航站
  • 用c 做网站免费模板下载网站
  • 六十岁一级a做爰片免费网站免费虚拟主机代理
  • 彩票网站建设制作网页制作图片模板
  • 志勋网站建设公司自己做网站的各种代码
  • 南宁网站制作公建筑企业官网
  • 网站建设包含项目中信建设官方网站
  • 成都企业网站建设哪家好微信小程序怎么做成链接
  • 网页制作与网站建设从入门到精通如何建立一个网站支持chrome
  • 营销型企业网站制作公司自学编程网站