LeetCode:261. 以图判树 - Python

这篇具有很好参考价值的文章主要介绍了LeetCode:261. 以图判树 - Python。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

261. 以图判树

问题描述:

给定从 0 n-1 标号的 n 个结点,和一个无向边列表(每条边以结点对来表示),请编写一个函数用来判断这些边是否能够形成一个合法有效的树结构。

示例 1:

输入:n = 5, 边列表 edges = [[0,1], [0,2], [0,3], [1,4]]
输出:true

示例 2:

输入:n = 5, 边列表 edges = [[0,1], [1,2], [2,3], [1,3], [1,4]]
输出:false

注意:
你可以假定边列表 edges 中不会出现重复的边。由于所有的边是无向边,边 [0,1] 和边 [1,0] 是相同的,因此不会同时出现在边列表 edges 中。

问题分析:

这题目有点贵呀,是LeetCode的VIP题目,第一次见还有点蒙,其实仔细想想也没啥难的。问题分析,判断一个无向图能否勾成一个树,很显然这个图要满足3个条件:

  1. 这个图不存在环
  2. 这个图所有节点是连通
  3. 这个图的边数一定为 n-1, 因为如果一棵树有n个节点,那么它的边一定是n-1
  4. 是不是可以得出这样的结论:如果有n-1条边且有环是一定是不连通,是不是可以说明,在n-1条边的条件下,只要判断是否有环即可?没有环路边数为n-1,就一定能构造成树?(没有严谨的证明哈,感觉反证法可以证明)

现在看看题目如何做?
(1)第一个条件就是判断这个图的边数是否等于n-1,很显然不符合就直接返回 False 即可。
(2)使用并查集的思想判断是否存在环路,如果存在环路直接返回 False,否则最后就返回 True

Python3实现:

# @Time   :2023/09/06
# @Author :Liu


class Solution:

    def validTree(self, n, edges):

        if len(edges) != n - 1:  # 边数是否等于 n - 1
            return False

        def find(x):  # 并查集查找
            if fa[x] != x:
                fa[x] = find(fa[x])
            return fa[x]

        fa = [i for i in range(n)]
        for x, y in edges:  # 判断两个点是否在同一个并查集里面
            fa_x = find(x)
            fa_y = find(y)

            if fa_x == fa_y:
                return False

            fa[fa_x] = fa_y

        return True


if __name__ == '__main__':
    solu = Solution()
    n, edges = 7, [[0, 1], [1, 2], [2, 3], [4, 5], [4, 6], [5, 6]]
    print(solu.validTree(n, edges))

相关参考:
[1]LeetCode:261. 以图判树 是VIP 题目,反正我是打不开。
[2] 代码参考: yiduobo的每日leetcode 261.以图判树。只在本地验证了,没有在线验证。
声明: 总结学习,有问题或不当之处,可以批评指正哦,谢谢。文章来源地址https://www.toymoban.com/news/detail-706940.html

到了这里,关于LeetCode:261. 以图判树 - Python的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • LeetCode(力扣)39. 组合总和Python

    LeetCode(力扣)39. 组合总和Python

    https://leetcode.cn/problems/combination-sum/description/

    2024年02月09日
    浏览(10)
  • LeetCode(力扣)37. 解数独Python

    LeetCode(力扣)37. 解数独Python

    https://leetcode.cn/problems/sudoku-solver/description/

    2024年02月09日
    浏览(11)
  • LeetCode(力扣)455. 分发饼干Python

    LeetCode(力扣)455. 分发饼干Python

    https://leetcode.cn/problems/assign-cookies/ 从大遍历 从小遍历

    2024年02月09日
    浏览(10)
  • python LeetCode 刷题记录 13

    题号:13 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。 通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特

    2024年02月08日
    浏览(8)
  • LeetCode(力扣)46. 全排列Python

    LeetCode(力扣)46. 全排列Python

    https://leetcode.cn/problems/permutations/

    2024年02月09日
    浏览(9)
  • python LeetCode 刷题记录 28

    给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 0 开始)。如果 needle 不是 haystack 的一部分,则返回 -1 。

    2024年02月08日
    浏览(12)
  • leetcode(算法) 70.爬楼梯(python版)

    leetcode(算法) 70.爬楼梯(python版)

    假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n = 2 输出:2 解释:有两种方法可以爬到楼顶。 1 阶 + 1 阶 2 阶 示例 2: 输入:n = 3 输出:3 解释:有三种方法可以爬到楼顶。 1 阶 + 1 阶

    2024年02月20日
    浏览(10)
  • LeetCode(力扣)134. 加油站Python

    LeetCode(力扣)134. 加油站Python

    https://leetcode.cn/problems/gas-station/description/

    2024年02月09日
    浏览(10)
  • LeetCode:53. 最大子数组和 - Python

    53. 最大子数组和 问题描述: 给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组 是数组中的一个连续部分。 示例 1: 输入:nums = [-2,1,-3,4,-1,2,1,-5,4] 输出:6 解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。 提示

    2024年02月11日
    浏览(13)
  • Leetcode题解-算法-动态规划(python版)

    1.1 爬楼梯 70. 爬楼梯(Easy) 走n阶楼梯的方法有两种,1、先走 1 级台阶,再走 n-1 级台阶;2、先走 2 级台阶,再走 n-2 级台阶 f(n) = f(n-1) + f(n-2) 1.2 强盗抢劫 198. 打家劫舍(Medium) 每个房间财产为 nums[0]……nums[n-1]。 假设 0 至 x 间房获得的最大财产为 f(x)。 f(x) = max(f(x-1),f(x-2)+nums[

    2024年02月03日
    浏览(14)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包