算法训练Day37|738.单调递增的数字 ● 968.监控二叉树

简介: 算法训练Day37|738.单调递增的数字 ● 968.监控二叉树
LeetCode:738.单调递增的数字

738. 单调递增的数字 - 力扣(LeetCode)

1.思路

倒序遍历,将当前位置数字与之后数字进行比较,当大于后者,做--同时后者取9,当小于时继续遍历即可,最后将start + 1及之后位置的数值赋为9.

2.代码实现

 1// 
 2class Solution {
 3    public int monotoneIncreasingDigits(int n) {
 4        String s = String.valueOf(n);
 5        char[] ch = s.toCharArray();
 6
 7        int start = ch.length;
 8        for (int i = ch.length - 2; i >= 0; i--) {
 9            if (ch[i] > ch[i + 1]) {
10                ch[i]--;
11                start = i + 1;
12            }
13        }
14        for (int i = start ; i < ch.length; i++) {
15            ch[i] = '9';
16        }
17        return Integer.parseInt(String.valueOf(ch));
18    }
19}
20
21
22// ChatGPT打辅助
23class Solution {
24    public int monotoneIncreasingDigits(int n) {
25        // 将整数n转换为字符串
26        String s = String.valueOf(n);
27        // 将字符串转换为字符数组
28        char[] chars = s.toCharArray();
29        // 记录需要修改的起始位置,默认为字符串的长度
30        int start = s.length();
31        // 从倒数第二位开始向前遍历字符数组
32        for (int i = s.length() - 2; i >= 0; i--) {
33            // 如果当前字符大于后一个字符,则将当前字符减1,并记录修改的起始位置
34            if (chars[i] > chars[i + 1]) {
35                chars[i]--;
36                start = i + 1;
37            }
38        }
39        // 将修改起始位置后的所有字符置为9
40        for (int i = start; i < s.length(); i++) {
41            chars[i] = '9';
42        }
43        // 将字符数组转换为整数并返回
44        return Integer.parseInt(String.valueOf(chars));
45    }
46}
47
48
49// 暴力实现:超时
50class Solution {
51    public int monotoneIncreasingDigits(int n) {
52        // 个位数 -> 十位数 -> ...
53        List<Integer> res = new ArrayList<>();
54        for (int i = n; i >= 0; i--) {
55            if (isMonotoneIncreasing(i)) {
56                res.add(i);
57                break;
58            }
59        }
60        return res.get(res.size() - 1);
61    }
62
63    public boolean isMonotoneIncreasing(int number) {
64        int prevDigit = Integer.MAX_VALUE;
65        while (number > 0) {
66            int curDigit = number % 10;
67            if (curDigit > prevDigit) {
68                return false;
69            }
70            prevDigit = curDigit;
71            number /= 10;
72        }
73        return true;
74    }
75}

3.复杂度分析

时间复杂度:O(n + m).

空间复杂度:O(1).


4.方法及心得

数字转为字符串,再转为字符数组(String修饰的字符串不可变,不能直接修改)

Integer.parseInt(String.valueOf(ch)) 是将字符数组 ch 转换为整数的方法。

首先,String.valueOf(ch) 将字符数组 ch 转换为一个字符串。然后,Integer.parseInt() 方法将该字符串解析为一个整数。

具体来说,Integer.parseInt() 方法将字符串中的字符按照整数的规则进行解析。它会忽略字符串开头和末尾的空格,并且可以处理正负号。如果字符串无法解析为一个合法的整数,Integer.parseInt() 方法会抛出一个 NumberFormatException 异常。


LeetCode:968.监控二叉树

968. 监控二叉树 - 力扣(LeetCode)


1.思路

很多情况导致难以下手,首先可以想遍历顺序,前?中?后?孩子节点大于根节点,选择后序可以尽可能少的放置一些摄像头。其次,放置摄像头的情况,①孩子节点的父节点放置摄像头,并作标记0,无覆盖;②左孩子或右孩子某一个无覆盖,摄像头+1;③其他情况表示有覆盖返回2;


2.代码实现

 1class Solution {
 2    int res = 0;
 3    public int minCameraCover(TreeNode root) {
 4
 5        if (minCame(root) == 0) {
 6            res++;
 7        }
 8        return res;
 9    }
10    public int minCame(TreeNode root) {
11        if (root == null) {
12            return 2;
13        }
14
15        int left = minCame(root.left);
16        int right = minCame(root.right);
17
18        if (left == 2 && right == 2) {
19            return 0;
20        } else if (left == 0 || right == 0) {
21            res++;
22            return 1;
23        } else {
24            return 2;
25        }
26    }
27}

3.复杂度分析

时间复杂度:O(n).

空间复杂度:O(n).

相关文章
|
4天前
|
存储 监控 算法
员工电脑监控系统中的 C# 链表算法剖析-如何监控员工的电脑
当代企业管理体系中,员工电脑监控已成为一个具有重要研究价值与实践意义的关键议题。随着数字化办公模式的广泛普及,企业亟需确保员工对公司资源的合理利用,维护网络安全环境,并提升整体工作效率。有效的电脑监控手段对于企业实现这些目标具有不可忽视的作用,而这一过程离不开精妙的数据结构与算法作为技术支撑。本文旨在深入探究链表(Linked List)这一经典数据结构在员工电脑监控场景中的具体应用,并通过 C# 编程语言给出详尽的代码实现与解析。
28 5
|
10天前
|
监控 算法 安全
基于 Python 广度优先搜索算法的监控局域网电脑研究
随着局域网规模扩大,企业对高效监控计算机的需求增加。广度优先搜索(BFS)算法凭借其层次化遍历特性,在Python中可用于实现局域网内的计算机设备信息收集、网络连接状态监测及安全漏洞扫描,确保网络安全与稳定运行。通过合理选择数据结构与算法,BFS显著提升了监控效能,助力企业实现智能化的网络管理。
26 7
|
11天前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
43 9
 算法系列之数据结构-二叉树
|
15天前
|
运维 监控 算法
监控局域网其他电脑:Go 语言迪杰斯特拉算法的高效应用
在信息化时代,监控局域网成为网络管理与安全防护的关键需求。本文探讨了迪杰斯特拉(Dijkstra)算法在监控局域网中的应用,通过计算最短路径优化数据传输和故障检测。文中提供了使用Go语言实现的代码例程,展示了如何高效地进行网络监控,确保局域网的稳定运行和数据安全。迪杰斯特拉算法能减少传输延迟和带宽消耗,及时发现并处理网络故障,适用于复杂网络环境下的管理和维护。
|
15天前
|
监控 算法 安全
关于公司电脑桌面监控中 PHP 二叉搜索树算法的深度剖析
在现代企业管理中,公司电脑桌面监控系统通过二叉搜索树(BST)算法保障信息安全和提高效率。本文探讨PHP中的BST在监控场景的应用,包括节点定义、插入与查找操作,并展示如何管理时间戳数据,以快速查询特定时间段内的操作记录。BST的高效性使其成为处理复杂监控数据的理想选择。
24 2
|
16天前
|
存储 缓存 监控
企业监控软件中 Go 语言哈希表算法的应用研究与分析
在数字化时代,企业监控软件对企业的稳定运营至关重要。哈希表(散列表)作为高效的数据结构,广泛应用于企业监控中,如设备状态管理、数据分类和缓存机制。Go 语言中的 map 实现了哈希表,能快速处理海量监控数据,确保实时准确反映设备状态,提升系统性能,助力企业实现智能化管理。
29 3
|
17天前
|
存储 监控 算法
公司监控上网软件架构:基于 C++ 链表算法的数据关联机制探讨
在数字化办公时代,公司监控上网软件成为企业管理网络资源和保障信息安全的关键工具。本文深入剖析C++中的链表数据结构及其在该软件中的应用。链表通过节点存储网络访问记录,具备高效插入、删除操作及节省内存的优势,助力企业实时追踪员工上网行为,提升运营效率并降低安全风险。示例代码展示了如何用C++实现链表记录上网行为,并模拟发送至服务器。链表为公司监控上网软件提供了灵活高效的数据管理方式,但实际开发还需考虑安全性、隐私保护等多方面因素。
21 0
公司监控上网软件架构:基于 C++ 链表算法的数据关联机制探讨
|
19天前
|
监控 网络协议 算法
基于问题“如何监控局域网内的电脑”——Node.js 的 ARP 扫描算法实现局域网内计算机监控的技术探究
在网络管理与安全领域,监控局域网内计算机至关重要。本文探讨基于Node.js的ARP扫描算法,通过获取IP和MAC地址实现有效监控。使用`arp`库安装(`npm install arp`)并编写代码,可定期扫描并对比设备列表,判断设备上线和下线状态。此技术适用于企业网络管理和家庭网络安全防护,未来有望进一步提升效率与准确性。
33 8
|
23天前
|
缓存 监控 算法
内网监控管理软件:PHP 语言队列算法揭秘
在数字化办公环境中,内网监控管理软件对企业的稳定运行和信息安全至关重要。本文深入介绍PHP中的队列算法及其在内网监控软件中的应用,包括监控数据收集、任务调度和日志记录等场景,通过代码示例展示其实现方法。队列算法可提高性能、保证数据顺序并实现异步处理,为企业提供高效的安全保障。
23 1
|
26天前
|
存储 监控 算法
员工屏幕监控系统之 C++ 图像差分算法
在现代企业管理中,员工屏幕监控系统至关重要。本文探讨了其中常用的图像差分算法,该算法通过比较相邻两帧图像的像素差异,检测屏幕内容变化,如应用程序切换等。文中提供了C++实现代码,并介绍了其在实时监控、异常行为检测和数据压缩等方面的应用,展示了其实现简单、效率高的特点。
45 15

热门文章

最新文章