查看: 344|回复: 2
收起左侧

[树/链表/图] 谁能给挨步讲讲这道宇宙难题1483. Kth Ancestor of a Tree Node讨论区中lee215的答案

|只看干货
ATPtennis | 显示全部楼层 |阅读模式
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   93% (44)
 
 
6% (3)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
step = 15
    def __init__(self, n, A):
        A = dict(enumerate(A))
        jump = [A]
        for s in xrange(self.step):
            B = {}
            for i in A:
                if A[i] in A:
                    B[i] = A[A[i]]
            jump.append(B)
            A = B
        self.jump = jump

    def getKthAncestor(self, x, k):
        step = self.step
        while k > 0 and x > -1:
            if k >= 1 << step:
                x = self.jump[step].get(x, -1)
                k -= 1 << step
            else:
                step -= 1
        return x

step = 15又是在说什么?我整个过程被self弄懵了。。。。。。。。

评分

参与人数 1大米 +1 收起 理由
14417335 + 1

查看全部评分


上一篇:差分数组是什么意思?
下一篇:Python 没有的class 面试时怎么办?
Rorshach 2021-10-24 06:35:09 来自APP | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   97% (1468)
 
 
2% (37)    👎
不是写python的,看不懂代码。但这个题最基本的思路就是倍增,通过预处理维护每个点往上2^i的祖先,然后每次询问就可以把kth分解成不同的2^i往上跳。


step=15是因为指数i最多只能是15,因为数据限制一个点最多只能有往上不到2^15的祖先


这里很难讲清楚,建议搜树上倍增,很多博客都会讲这个

评分

参与人数 1大米 +2 收起 理由
14417335 + 2

查看全部评分

回复

使用道具 举报

 楼主| ATPtennis 2021-10-24 06:39:13 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   93% (44)
 
 
6% (3)    👎
Rorshach 发表于 2021-10-24 00:35
不是写python的,看不懂代码。但这个题最基本的思路就是倍增,通过预处理维护每个点往上2^i的祖先,然后每 ...

OK,这就去搜,谢谢!!!!

评分

参与人数 1大米 +1 收起 理由
sdfzDS + 1 赞一个

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表