- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想重构我编写的递归树打印函数,以便根节点(第一个调用)完全不缩进。
Tree = dict[str, 'Tree']
def print_tree(tree: Tree, prefix: str=''):
if not tree:
return
markers = [('├── ', '│ '), ('└── ', ' ')]
children = list(tree.items())
for key, subtree in children:
is_last_child = (key, subtree) == children[-1]
key_prefix, subtree_prefix = markers[is_last_child]
print(prefix + key_prefix + key)
print_tree(subtree, prefix + subtree_prefix)
tree = {'.': {'alpha':{}, 'beta': {'beta.alpha':{}, 'beta.beta':{}}, 'charlie': {'charlie.alpha':{}, 'charlie.beta':{}, 'charlie.charlie':{}}, 'delta':{}}}
print_tree(tree)
当前输出为
└── .
├── alpha
├── beta
│ ├── beta.alpha
│ └── beta.beta
├── charlie
│ ├── charlie.alpha
│ ├── charlie.beta
│ └── charlie.charlie
└── delta
但我希望输出是
.
├── alpha
├── beta
│ ├── beta.alpha
│ └── beta.beta
├── charlie
│ ├── charlie.alpha
│ ├── charlie.beta
│ └── charlie.charlie
└── delta
我想不出一种优雅的方式来完成它,就像在没有特殊外壳的情况下这样的第一个调用:
def print_tree(tree: Tree, prefix: str='', root: bool=True):
if not tree:
return
markers = [('├── ', '│ '), ('└── ', ' ')]
if root:
markers = [('', ''), ('', '')]
children = list(tree.items())
for key, subtree in children:
is_last_child = (key, subtree) == children[-1]
key_prefix, subtree_prefix = markers[is_last_child]
print(prefix + key_prefix + key)
print_tree(subtree, prefix + subtree_prefix, root=False)
我怎样才能改变我递归的方式来完成这个?我不想向函数添加额外的参数或以其他方式需要有关状态的更多信息。我喜欢我当前的功能是多么简单,它只是在我真的不想要它时为第一级添加前缀。
最佳答案
漂亮的算法,我喜欢! (比 mine 好多了)
这是我在您给定的约束条件下所能做的最好的事情:
Tree = dict[str, 'Tree']
def print_tree(tree: Tree, prefix: str=None):
markers = [('├── ', '│ '), ('└── ', ' '), ('', '')]
for i, (key, subtree) in enumerate(tree.items()):
is_last_child = i == len(tree) - 1
marker_index = 2 if prefix is None else is_last_child
prefix = prefix or ""
key_prefix, subtree_prefix = markers[marker_index]
print(prefix + key_prefix + key)
print_tree(subtree, prefix + subtree_prefix)
tree = {'.': {'alpha':{}, 'beta': {'beta.alpha':{}, 'beta.beta':{}}, 'charlie': {'charlie.alpha':{}, 'charlie.beta':{}, 'charlie.charlie':{}}, 'delta':{}}}
print_tree(tree)
.
├── alpha
├── beta
│ ├── beta.alpha
│ └── beta.beta
├── charlie
│ ├── charlie.alpha
│ ├── charlie.beta
│ └── charlie.charlie
└── delta
None
将 root
指示符存储在 prefix
中enumerate
替换 children
列表,使用 i
检查它是否是最后一个 child 关于python - 不要在递归树打印机中缩进第一层树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74484283/
我正在使用 libxml2 的 xmlwriter api 编写一个 xml 文件。 当我使用记事本打开文件时,缩进不正确。 有人知道怎么解决吗? 非常感谢。 最佳答案 我在这里有点冒进,但我会说“缩
我正在尝试让这个脚本工作,但它...给我缩进错误 #!/usr/bin/env python import io myfile = open('stats.txt', 'r') dan = myfil
我使用 Emacs 有一段时间了,我真的很想念一个古老的 Geany 快捷方式 - “C-i”和“C-u”。 “C-i”缩进整个当前行(将鼠标光标保持在原处),“C-u”取消整个当前行的缩进。 我发现
如何向 UILabel 内的文本添加缩进或偏移?它需要是特定的像素大小,与字体大小无关。 最佳答案 您可以创建另一个UILabel,然后将每个标签的框架设置为一定的宽度,这样,如果您想要实现这一目标,
请帮我在 Emacs haskell-mode 中设置正确的缩进 当我尝试输入诸如 ADT 或记录之类的内容时,按 后我进入了错误的列。 ,然后按 不会切换到右边,直到我输入 |或者 ';'! d
我在 Visio 2010 中有一个项目符号列表,我试图在其中缩进二级项目符号。例如: 我希望“子项目符号”项目向右缩进,这样很明显它是一个子元素。我认为功能区上的“增加缩进”选项可以做到这一点,但这
我写了这段代码: addNums key num = add [] key num where add res a:as b:bs | a == [] = res
我在生成的 xml 文档中添加了换行符。 "\n" some text etc."\n" "\n" 这最终应该是: some text etc. 这是否可以通过 google-code-pre
使用 JTabbedPane 时,如何缩进选项卡? Swing 默认输出: ------- --------- ------ | A | | B | | C | --------
我收到这些行的缩进错误 有没有在线验证器可以帮助我? showAliveTests : (pageIndex, statusFilter) -> data= pageI
在 Python 中,当你写了 100 行代码而忘记在某个地方添加一堆循环语句时,你会怎么做? 我的意思是,如果您在某处添加一个 while 语句,您现在必须缩进它下面的所有行。这不像您可以戴上牙套并
我喜欢这样做,如 indesign 或 quark...段落缩进...图片 如何在 html 和 css 中做到这一点的正确方法 我不希望文字环绕图像...我喜欢保护整个左边的部分给图片留边距就可以了
我试过添加 10px 的内边距但没有成功。你可以看到它的一个例子lower down on this page . #menu li { float: left;
这个问题在这里已经有了答案: I'm getting an IndentationError. How do I fix it? (6 个答案) 关闭去年。 while 1 == 1:
您好,我正在尝试使用来自 C# 应用程序的收据打印机打印帐单/收据。 预期的输出是这样的: ITEM NAME QTY PRICE Banana Large Y
有没有办法在 JTextPane 中缩进一段文本? import javax.swing.*; import java.awt.*; import javax.swing.text.StyledDoc
我知道 #define 等通常从不缩进。为什么? 我目前正在编写一些代码,其中混合了#define、#ifdef、#else s、#endifs 等。所有这些通常与普通 C 代码混合在一起。 #def
我认为缩进在 YAML 中很重要。 我在 irb 中测试了以下内容: > puts({1=>[1,2,3]}.to_yaml) --- 1: - 1 - 2 - 3 => nil 我期待这样的事情:
我在带有 openmp 语句的 C++ 代码中使用 Vim。 而在我的 ~/.vimrc set ai " auto indent 我的问题:当我使用 openmp 语句(以 # 开头)时,光标会跳
我想使用 Megaparsec 解析一种基本的缩进语言。最初我使用的是 Parsec,我设法通过缩进正常工作,但现在我遇到了一些麻烦。 我一直在关注一个教程here这是我必须解析一种忽略缩进的语言的代
我是一名优秀的程序员,十分优秀!