假设我有一个这样的字符串列表:
['001+11', '010+10', '011+01', '100+11']
我想得到这个:
['0*0*1+1*1', '0*1*0+1*0', '0*1*1+0*1', '1*0*0+1*1']
我知道这里的条件是,只要有 0 或 1,我们必须用数字+“*”替换数字,但当数字的下一个元素是“+”时不要这样做。所以我写了一个 python 代码如下-
binary=["0","1"]
for string in out:#out is the list of strings
for i in range(len(string)):
if string[i] in binary:
out[out.index(string)]=change(string,string[i],string[i]+"*")
break
print out
这使输出为-
['0*01+01', '0*00+01', '0*11+00', '0*10+00', '1*01+11', '1*00+11', '1*11+10', '1*10+10']
所以,我意识到如果我再运行一个“while循环”,我会得到我想要的(一个while循环,因为我们必须提到“for循环”中的循环重复次数,这里不是一个选择)。但是我无法弄清楚while的条件应该是什么。很多这一切听起来有点复杂,所以我想,也许还有其他方法可以实现我想要的东西。因此,问题。
注意——这是一个更大的程序的一部分,用于从任何不是用 Python 格式编写的布尔表达式中获取真值表。如果这部分得到解决,其余的可能可以使用 eval 来解决。提前致谢!
EDIT1--change 是一个用户定义的函数,它改变一个更大字符串的子字符串。
def change(string,old,new):
pos=string.index(old)
return string[:pos]+new+string[pos+1:]