
按顺序排列组合输出字符串
问题:
如何将嵌套列表中第一个列表中的第一个元素到最后一个列表中的最后一个元素,按顺序遍历并组合成字符串输出?
解答:
分割列表:
将嵌套列表拆分为多变量,分别为:
a0 = strlst[0] a1 = strlst[1] a2 = strlst[2] a3 = strlst[3] a4 = strlst[4]
计算元素数量:
计算每个分割出的变量中的字符串数量:
l0 = len(a0) l1 = len(a1) l2 = len(a2) l3 = len(a3) l4 = len(a4)
计数器:
初始化计数器并将计数限制为全部元素的组合数量:
n0 = 0 n1 = 0 n2 = 0 n3 = 0 n4 = 0 sum = l0 * l1 * l2 * l3 * l4 count = 0
遍历环:
进入 while 循环,执行以下步骤,直到 count 达到其限制:
while count < sum:
# 使用满位进一的算法遍历计数器
...
# 输出段,按需添加缩进并连接字符串
...
# 更新计数器和 count
...输出:
循环完成后,将组合的字符串输出到控制台。
示例代码:
以下代码根据问题提供了示例输出:
strlst = [['cmd1'],['opt1-1','opt1-2',''],['opt1-3'],['opt1-4',''],['opt1-5','']]
a0 = strlst[0]
a1 = strlst[1]
a2 = strlst[2]
a3 = strlst[3]
a4 = strlst[4]
l0 = len(a0)
l1 = len(a1)
l2 = len(a2)
l3 = len(a3)
l4 = len(a4)
n0 = 0
n1 = 0
n2 = 0
n3 = 0
n4 = 0
sum = l0 * l1 * l2 * l3 * l4
count = 0
while count < sum:
if n4 >= l4:
n4 = 0
n3 += 1
if n3 >= l3:
n3 = 0
n2 += 1
if n2 >= l2:
n2 = 0
n1 += 1
if n1 >= l1:
n1 = 0
n0 += 1
if n0 >= l0:
n0 = 0
needoutput = ''
if a0[n0] != '':
needoutput = needoutput + a0[n0] + '\t'
else:
needoutput = needoutput + a0[n0]
if a1[n1] != '':
needoutput = needoutput + a1[n1] + '\t'
else:
needoutput = needoutput + a1[n1]
if a2[n2] != '':
needoutput = needoutput + a2[n2] + '\t'
else:
needoutput = needoutput + a2[n2]
if a3[n3] != '':
needoutput = needoutput + a3[n3] + '\t'
else:
needoutput = needoutput + a3[n3]
if a4[n4] != '':
needoutput = needoutput + a4[n4]
needoutput = needoutput.expandtabs(7)
print(needoutput)
n4 += 1
count += 1输出:
cmd1 opt1-1 opt1-3 opt1-4 opt1-5 cmd1 opt1-1 opt1-3 opt1-4 cmd1 opt1-1 opt1-3 opt1-5 cmd1 opt1-1 opt1-3 cmd1 opt1-2 opt1-3 opt1-4 opt1-5 cmd1 opt1-2 opt1-3 opt1-4 cmd1 opt1-2 opt1-3 opt1-5 cmd1 opt1-2 opt1-3 cmd1 opt1-3 opt1-4 opt1-5 cmd1 opt1-3 opt1-4 cmd1 opt1-3 opt1-5 cmd1 opt1-3
以上就是如何将嵌套列表中各个子列表所有元素组合成字符串,并按顺序输出?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号