当前位置: 首页 > wzjs >正文

托管的服务器如何做网站上海网络推广优化公司

托管的服务器如何做网站,上海网络推广优化公司,网站建设与制作价格,北京网站建设公司排名浩森宇特文章目录 习题1483.树节点的第K个祖先拓展:LCA LCA问题,就是最近公共祖先的问题 习题 1483.树节点的第K个祖先 1483.树节点的第K个祖先 普通的做法,当然是一个个往上面搜索,但是这样的话时间复杂度是o(k),那么能不能每次求解的是…

文章目录

  • 习题
    • 1483.树节点的第K个祖先
      • 拓展:LCA

  • LCA问题,就是最近公共祖先的问题

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

习题

1483.树节点的第K个祖先

1483.树节点的第K个祖先

在这里插入图片描述

  • 普通的做法,当然是一个个往上面搜索,但是这样的话时间复杂度是o(k),那么能不能每次求解的是爷爷节点,这样就是按照二进制的步子进行寻找

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

class TreeAncestor:def __init__(self, n: int, parent: List[int]):# bit_length()表示二进制的位数,因为pa[x][0]直接就是父亲节点,所以只用少一位即可m = n.bit_length() - 1# 初始化pa = [[p] + [-1]*m for p in parent]# 注意这个遍历,先枚举这个i再枚举这个x,先算出全部节点的所有爷爷节点,再算出所有爷爷的爷爷节点for i in  range(m):for x in range(n):p = pa[x][i]if p != -1:pa[x][i+1] = pa[p][i]self.pa = padef getKthAncestor(self, node: int, k: int) -> int:for i in range(k.bit_length()):# 这个k>>i的判断就十分巧妙# 并且这个node 是全局的,i从0开始判断if (k >> i) & 1:node = self.pa[node][i]if node < 0 :breakreturn node

拓展:LCA

在这里插入图片描述
在这里插入图片描述

  • 初始化
# 
class TreeAncestor:def __init__(self, edges: List[List[int]]):n = len(edges) + 1m = n.bit_length()g = [[] for _ in range(n)]for x, y in edges:  # 节点编号从 0 开始g[x].append(y)g[y].append(x)depth = [0] * npa = [[-1] * m for _ in range(n)]def dfs(x: int, fa: int) -> None:pa[x][0] = fafor y in g[x]:if y != fa:depth[y] = depth[x] + 1dfs(y, x)dfs(0, -1)for i in range(m - 1):for x in range(n):if (p := pa[x][i]) != -1:pa[x][i + 1] = pa[p][i]self.depth = depthself.pa = padef get_kth_ancestor(self, node: int, k: int) -> int:for i in range(k.bit_length()):if (k >> i) & 1:  # k 二进制从低到高第 i 位是 1node = self.pa[node][i]return node# 返回 x 和 y 的最近公共祖先(节点编号从 0 开始)def get_lca(self, x: int, y: int) -> int:if self.depth[x] > self.depth[y]:x, y = y, x# 使 y 和 x 在同一深度y = self.get_kth_ancestor(y, self.depth[y] - self.depth[x])if y == x:return xfor i in range(len(self.pa[x]) - 1, -1, -1):px, py = self.pa[x][i], self.pa[y][i]if px != py:x, y = px, py  # 同时上跳 2**i 步return self.pa[x][0]
http://www.dtcms.com/wzjs/474832.html

相关文章:

  • 可以发布广告的网站网站服务公司
  • 商城网站的开发怎么做珠海网络推广公司
  • 织梦cms怎么搭建网站全网营销推广系统
  • 网站建设衤金手指花总网店运营在哪里学比较好些
  • 庆阳网站设计 贝壳下拉购买友情链接
  • 主体负责人和网站负责人不能是同一个人电脑培训机构哪个好
  • 萝岗网站建设优化百度做免费推广的步骤
  • 网页设计用到的技术windows优化大师官方免费下载
  • 微信公众号人工服务电话上海有什么seo公司
  • 郑州网站建设灵秀手机百度极速版
  • 济南多语言网站建设电商运营推广是做什么的
  • cn域名做犯法网站熊猫关键词工具
  • 长沙网站制作培训基地黑帽seo培训大神
  • 牌具网站广告怎么做网络营销策划推广
  • 怎么注册晋江网站做的最新提升关键词排名软件
  • 3网站建设公司nba体育新闻
  • 在线做行测的网站色盲测试卡
  • wordpress 页面打不开熊猫seo实战培训
  • 专业提供网站建设服务写软文赚钱的平台都有哪些
  • 济南网站建设公seo简介
  • 网站层级b2b网站源码
  • 做网站要做哪些公司官网怎么制作
  • 郫县哪里有做网站的成都百度推广优化创意
  • 在灵璧怎样做网站什么叫网络市场营销
  • 一站式建设网站广东网约车涨价
  • 株洲新闻网红网株洲站百度大数据查询怎么用
  • 东莞网站SEO优化推广seo首页优化
  • 建立动态网站的作用权重查询爱站网
  • 台中网站建设无锡seo网站排名
  • 网站关键词多长域名检测工具