美文网首页
搜索,动态规划,二叉树的时间复杂度计算通用公式

搜索,动态规划,二叉树的时间复杂度计算通用公式

作者: 鸭蛋蛋_8441 | 来源:发表于2019-06-23 06:22 被阅读0次

    搜索的时间复杂度:O(答案总数 * 构造每个答案的时间)

    举例:Subsets问题,求所有的子集。子集个数一共 2^n,每个集合的平均长度是 O(n) 的,所以时间复杂度为 O(n * 2^n),同理 Permutations 问题的时间复杂度为:O(n * n!)

    动态规划的时间复杂度:O(状态总数 * 计算每个状态的时间复杂度)

    举例:triangle,数字三角形的最短路径,状态总数约 O(n^2) 个,计算每个状态的时间复杂度为 O(1)——就是求一下 min。所以总的时间复杂度为 O(n^2)

    用分治法解决二叉树问题的时间复杂度:O(二叉树节点个数 * 每个节点的计算时间)

    举例:二叉树最大深度。二叉树节点个数为 N,每个节点上的计算时间为 O(1)。总的时间复杂度为 O(N)

    相关文章

      网友评论

          本文标题:搜索,动态规划,二叉树的时间复杂度计算通用公式

          本文链接:https://www.haomeiwen.com/subject/chobqctx.html