如何解决Python中的序列计数
我编写了一个 python 代码来计算给定序列中可能的对的数量。但是我必须一遍又一遍地运行代码,同时更改距离参数,以获取所有可能的距离不同的对。我想优化我的代码,但我不知道如何做到这一点。例如:当我运行我的代码时,我得到了 AB、BC、CD、DE、EF、FG、GH 对。这是字母之间距离为 1 的配对可能性。但我也想打印其他可能性,例如,当距离为 2 时,对将是 AC、BD、CE、DF、EH、FG,对于其他距离也是如此。我想编写一个代码来给我所有可能的输出。目前,我必须将“if(0
seq = "ABCDEFHG"
l = []
for i in range(len(seq)):
if(0<=i<7):
c1 = seq[i]
c2 = seq[i+1]
l.append(c1+c2)
print(l)
解决方法
这不是 try-except 的最有效原因,但我猜它在您的用例中并不重要。
无论如何,给你:
seq = "ABCDEFHG"
l = []
for k in range(1,len(seq)):
for i in range(len(seq)):
if(i<len(seq)-1):
try:
c1 = seq[i]
c2 = seq[i+k]
l.append(c1+c2)
except:
pass
print(l)
l.clear()
,
不确定这是否是您想要的,但请查看:
seq = "ABCDEFHG"
length = len(seq)
for d in range(1,length):
l = []
for i in range(length):
if(0<=i<length-d):
c1 = seq[i]
c2 = seq[i+d]
l.append(c1+c2)
print("Distance {} : {}".format(d,l))
输出:
Distance 1 : ['AB','BC','CD','DE','EF','FH','HG']
Distance 2 : ['AC','BD','CE','DF','EH','FG']
Distance 3 : ['AD','BE','CF','DH','EG']
Distance 4 : ['AE','BF','CH','DG']
Distance 5 : ['AF','BH','CG']
Distance 6 : ['AH','BG']
Distance 7 : ['AG']
,
您可以使用嵌套的 for 循环来做到这一点。
seq = "ABCDEFHG"
l = []
for i in range(len(seq)):
for j in range(i + 1):
if j != i:
l.append(seq[j] + seq[i])
l.sort()
print(l)
输出
['AB','AC','AD','AE','AF','AG','AH','BG','CG','DG','EG','FG','HG']
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。