- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在 Python 中有一个字典形式的邻接表: {1:[2,3], 2:[4,5,6], 3:[7,8]}
我的 findleaf() 看起来像这样
def findleaf(d):
keylist= list(d.keys())
leaf = []
for i in d:
valList = d[i]
for j in valList:
if j not in keylist:
leaf.append(j)
return leaf
所以上述方法返回的叶子为 [4,5,6,7,8] 但我也想知道它们是否在同一层。
首先想到的是求起始节点到叶节点的路径,然后求其长度。但是我们能做得更好吗?甚至在上面提到的相同函数中,我们返回叶子及其高度。
最佳答案
您可以使用 DFS 并维护一个 DEEP 变量。当您找到一片叶子时,将叶子的编号和 DEEP 添加到容器中。
d = {1:[2,3],2:[4,5,6], 3:[7,8]}
ans = []
deep = 1
keylist = list(d.keys())
def findleaf(n,deep):
if n not in keylist:
ans.append([n,deep])
else:
l = d[n]
for i in l:
findleaf(i,deep+1)
findleaf(1,deep)
print(ans)
输出:[[4, 3], [5, 3], [6, 3], [7, 3], [8, 3]]
关于python - 查找是否所有叶节点都处于相同高度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54061531/
我正在尝试从底层叶进程写入命名管道并从顶层进程的管道读取。 为此,我首先在顶级进程中创建 FIFO,然后使用 for 循环派生更多进程。在 for 循环中,我正在检查叶子进程,如果它是叶子,我正在写入
我需要一个XPath表达式来验证XML列表元素是否只有某种类型的节点。 例: 我需要知道列表中是否只有图像。
我想从层次结构表中获取所有叶子及其根。叶子是最低层节点,根是最顶层节点。 给定一棵树: A --B --C --D E --F --G --H 叶子是节点:C, D根是:A、E 该表如下所
尝试从嵌套数组中删除相同的 sibling (叶子)/相同的数组。 例如 $data = [ 'test' => [ 'a' => [
我可以遍历目录并只打印文件夹/目录名称,但我想排除包含其他目录的目录的文件夹名称。出于某种原因,我称其为树结构中的“最终节点”,但我很可能是在自欺欺人,这不是第一次了。 =) 在审查其他答案列表时,也
我现在经常使用 Folium,在 Python 中拥有如此易于使用的东西真的很棒。但是他们的文档严重落后,我理解。所以我有2个问题。 我在尝试获得更多标记颜色时做错了什么?这是我尝试过的:map.si
我正在尝试使用 ape 包中的 plot.phylo 命令为 R 中系统发育类型图的边缘(线)添加颜色。这个例子是一个“粉丝”类型的图,虽然我希望这个方法与“系统图类型”或其他任何东西相同。 libr
我正在尝试呈现一个 JTree 叶以具有包含可编辑 JTextArea 的 JPanel,以便用户可以输入文本并能够在添加文本时向下滚动, 并且还使用包装器来限制文本的宽度,使其向下延伸以留出更多空间
这是要修改的正确 Linux 内核代码吗?我如何进行更改以模拟 CPUID 代码以及我需要更改哪个函数。谢谢 #include #include #include #include #incl
我是一名优秀的程序员,十分优秀!