代码随想录算法训练营第37天| Leetcode 738.单调递增的数字、968.监控二叉树

本文主要是介绍代码随想录算法训练营第37天| Leetcode 738.单调递增的数字、968.监控二叉树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • Leetcode 738.单调递增的数字
    • Leetcode 968.监控二叉树

Leetcode 738.单调递增的数字

题目链接:Leetcode 738.单调递增的数字
题目描述: 当且仅当每个相邻位数上的数字 xy 满足 x <= y 时,我们称这个整数是单调递增的。

给定一个整数 n ,返回 小于或等于n的最大数字,且数字呈单调递增 。
思路: 本题数据范围太大了,暴力解法肯定会超时,因此需要借助贪心思想优化。

  1. 如果是0~9的话返回其本身,也就是不需要任何操作
  2. 如果是10~99,我们可以判断十位数字与个位数字的大小,比如73,我们需要做的操作就是7--,然后3变成9,结果为69
  3. 对于三位数及以上数字,可以从后两位开始判断,将其变为单调递增数字(局部最优),再逐渐判断更高一位的数字,最终数字整体变成单调递增数字(全局最优)。

基于以上思路,我们可以发现从后向前遍历数字更适合。这里还有一个小技巧:可以将数字转换成字符串,这样可以轻松获得每一位上的数字。 尽管这样增加了空间复杂度,但是代码更好写了。

代码如下:

class Solution {
public:int monotoneIncreasingDigits(int n) {string s = to_string(n);//字符串更方便操作每一位上的数字//用flag标记从哪个位置之后全赋值为9int flag = s.size();for (int i = s.size() - 1; i > 0; i--) {if (s[i - 1] > s[i]) {flag = i;s[i - 1]--;}}for (int i = flag; i < s.size(); i++) {s[i] = '9';}return stoi(s);}
};
  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( n ) O(n) O(n)

Leetcode 968.监控二叉树

题目链接:Leetcode 968.监控二叉树
题目描述: 给定一个二叉树,我们在树的节点上安装摄像头。

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

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

思路: 本题可以利用贪心思想,由于二叉树自上向下的节点个数是以指数级别增长,也就是说我们需要尽可能的让摄像头向上放而不聚集在叶子节点,这样可以节省大量摄像头数量,对应的我们需要利用二叉树的后序遍历,只有这样才是从下向上的判断是否需要添加摄像头。

代码如下:

class Solution {
public:int result; //统计摄像头数量// 0代表无覆盖,1代表摄像头,2代表有覆盖int traversal(TreeNode* cur) {//空节点,假设为有覆盖if (cur == nullptr)return 2;int left = traversal(cur->left);int right = traversal(cur->right);//(1)左右孩子都为2,则父节点为0if (left == 2 && right == 2)return 0;//(2)左右孩子至少有一个为0,则父节点为1// 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)左右孩子至少有一个为1,则父节点为2if (left == 1 || right == 1)return 2;//所有情况已经讨论结束,但是没有这段代码leetcode编译不过return -1;}int minCameraCover(TreeNode* root) {result = 0;//不要漏掉这里:(4)回溯到最后可能根节点未被覆盖if (traversal(root) == 0)result++;return result;}
};
  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( n ) O(n) O(n)

这道题官方题解是动态规划,代码执行的行为类似,不过我感觉还是这种分类讨论+贪心的方法好理解。


总结: 贪心类题目多积累吧,遇到新题目没思路确实不好搞。

最后,如果文章有错误,请在评论区或私信指出,让我们共同进步!

这篇关于代码随想录算法训练营第37天| Leetcode 738.单调递增的数字、968.监控二叉树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/737476

相关文章

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

使用zabbix进行监控网络设备流量

《使用zabbix进行监控网络设备流量》这篇文章主要为大家详细介绍了如何使用zabbix进行监控网络设备流量,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装zabbix配置ENSP环境配置zabbix实行监控交换机测试一台liunx服务器,这里使用的为Ubuntu22.04(

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

springboot健康检查监控全过程

《springboot健康检查监控全过程》文章介绍了SpringBoot如何使用Actuator和Micrometer进行健康检查和监控,通过配置和自定义健康指示器,开发者可以实时监控应用组件的状态,... 目录1. 引言重要性2. 配置Spring Boot ActuatorSpring Boot Act

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st