我是一个编程的初学者,我正在尝试弄清楚列表方法是如何工作的。为了练习,我写了一个小小的字符串扰码器和解码器。你知道吗
import random
sliced = []
keyholder = []
scrambled = []
decoded = []
def string_slicer(string):
i = 0
while i < len(string):
sliced.append(string[i])
i += 1
def string_scrambler(string):
string = string_slicer(string)
a = 0
while len(scrambled) != len(sliced):
value = len(sliced) - 1
key = random.randint(0,value)
if key in keyholder:
continue
else:
scrambled.append(sliced[key])
keyholder.append(key)
continue
def string_decoder():
x = 0
for item in keyholder:
decoded.insert(keyholder[x], scrambled[x])
x += 1
string_scrambler('merhaba')
string_decoder()
print sliced
print keyholder
print scrambled
print decoded
当我测试它时,string\u scrambler()工作正常,但是string\u decoder()会给出随机结果。以下是一些示例:
C:\Python27\Exercises>python scrambler.py
['m', 'e', 'r', 'h', 'a', 'b', 'a']
[2, 6, 0, 1, 3, 5, 4]
['r', 'a', 'm', 'e', 'h', 'b', 'a']
['m', 'e', 'r', 'h', 'a', 'a', 'b']
C:\Python27\Exercises>python scrambler.py
['m', 'e', 'r', 'h', 'a', 'b', 'a']
[4, 5, 1, 0, 3, 2, 6]
['a', 'b', 'e', 'm', 'h', 'r', 'a']
['m', 'a', 'r', 'e', 'h', 'b', 'a']
C:\Python27\Exercises>python scrambler.py
['m', 'e', 'r', 'h', 'a', 'b', 'a']
[1, 4, 5, 2, 3, 0, 6]
['e', 'a', 'b', 'r', 'h', 'm', 'a']
['m', 'e', 'a', 'r', 'h', 'b', 'a']
我认为尝试使用.insert方法在空列表中添加某些项可能会导致此问题。但我不知道到底为什么。你知道吗
请注意,您的许多功能根本不是必需的。你知道吗
值得注意的是,您的方法的问题是您可能会尝试这样做,例如:
由于列表最初的长度为零,插入到结束点之后只会将其发送到列表的末尾。尽管
3
是一个比2
更遥远的索引,但它的顺序并不正确,因为基本上您已经完成了相反,你可以这样做:
然后去解扰,做相反的事情
我使用的完整解决方案,包括一些其他技巧,是:
注意:这会删除你最初尝试学习的所有列表方法!您应该注意到这一点,因为它表明了一个事实,即列表方法很慢(除了
append
和pop
),如果存在另一个同样可读的解决方案,您可能应该避免使用它们。你知道吗我认为最好不要用
list
作为decoded
的数据结构。 我将使用dict
作为临时变量,下面是我的字符串解码器版本:顺便说一句,您对
list.insert()
有问题,因为您将值插入列表中不存在的位置,例如,将第4项添加到包含2个元素的列表中。你知道吗行为示例:
相关问题 更多 >
编程相关推荐