代码随想录-算法训练营day36(贪心算法06:单调递增的数字,监控二叉树,总结)

bash 复制代码
第八章 贪心算法 part06
 
● 738.单调递增的数字 
● 968.监控二叉树 
● 总结 
 
 详细布置 
 738.单调递增的数字 
https://programmercarl.com/0738.%E5%8D%95%E8%B0%83%E9%80%92%E5%A2%9E%E7%9A%84%E6%95%B0%E5%AD%97.html  
 
 968.监控二叉树 (可以跳过)
 
本题是贪心和二叉树的一个结合,比较难,一刷大家就跳过吧。 
https://programmercarl.com/0968.%E7%9B%91%E6%8E%A7%E4%BA%8C%E5%8F%89%E6%A0%91.html  
 总结 
 
可以看看贪心算法的总结,贪心本来就没啥规律,能写出个总结篇真的不容易了。 
https://programmercarl.com/%E8%B4%AA%E5%BF%83%E7%AE%97%E6%B3%95%E6%80%BB%E7%BB%93%E7%AF%87.html

day36

单调递增的数字

复制代码
 class Solution {
     public int monotoneIncreasingDigits(int n) {
         //从后往前比较,前一位大则变小,并记录变成9的位置
         String s = String.valueOf(n);
         char ch[] = s.toCharArray();
         int flag = ch.length;
         for(int i = ch.length - 1; i > 0; i--){
             if(ch[i] < ch[i - 1]){
                 ch[i - 1]--;//为什么?哦,52变成49,而不是22
                 flag = i;//从flag开始后面都变成9
             }
         }
         for(int i = flag; i < ch.length; i++){
             //ch[i] = 9;//char类型,不正确
             ch[i] = '9';
         }
         return Integer.parseInt(String.valueOf(ch));
     }
 }

监控二叉树

复制代码
 class Solution {
     int result = 0;
     public int minCameraCover(TreeNode root) {
         //大体思路就是从低到上,先给叶子节点父节点放个摄像头,然后隔两个节点放一个摄像头,直至到二叉树头结点。
         if(traversal(root) == 0 ){//处理根节点无覆盖的情况
             result++;
         }
         return result;
     }
     private int traversal(TreeNode root){
         //三种状态,1有摄像头,2有覆盖,0无覆盖
         if( root == null) return 2;
         //后序遍历
         int left = traversal(root.left);
         int right = traversal(root.right);
         //当前节点处理
         if(left == 2 && right == 2) return 0;
         if(left == 0 || right == 0) {
             result++;
             return 1;
         }
         if( left == 1 || right == 1) return 2; 
         return -1;//走不到这一步
     }
 }

贪心算法总结:

感谢大佬分享:

代码随想录-算法训练营day36【贪心算法06:单调递增的数字、监控二叉树、总结】-CSDN博客

相关推荐
寻星探路5 分钟前
【前端基础】HTML + CSS + JavaScript 快速入门(三):JS 与 jQuery 实战
java·前端·javascript·css·c++·ai·html
你的冰西瓜22 分钟前
2026春晚魔术揭秘——变魔法为物理
算法
cyforkk33 分钟前
Tomcat 类加载机制解析:为何依赖包必须放在 WEB-INF/lib 目录下
java
忘梓.1 小时前
解锁动态规划的奥秘:从零到精通的创新思维解析(10)
c++·算法·动态规划·代理模式
foolish..1 小时前
动态规划笔记
笔记·算法·动态规划
消失的dk1 小时前
算法---动态规划
算法·动态规划
羑悻的小杀马特1 小时前
【动态规划篇】欣赏概率论与镜像法融合下,别出心裁探索解答括号序列问题
c++·算法·蓝桥杯·动态规划·镜像·洛谷·空隙法
绍兴贝贝1 小时前
代码随想录算法训练营第四十六天|LC647.回文子串|LC516.最长回文子序列|动态规划总结
数据结构·人工智能·python·算法·动态规划·力扣
JaJian.1 小时前
Java后端服务假死问题排查与解决
java·开发语言
愚润求学1 小时前
【动态规划】二维的背包问题、似包非包、卡特兰数
c++·算法·leetcode·动态规划