2

我有一个巨大的字符串,我试图将其解析为字符串形式的一系列标记,但我发现了一个问题:因为许多字符串都是相似的,有时这样做string.replace()会导致以前替换的字符再次被替换。

假设我要替换的字符串是“goto”,它被“41”(十六进制)替换并转换为 ASCII(“A”)。稍后,字符串'A'也将被替换,因此转换后的令牌再次被替换,导致问题。

让字符串只更换一次的最佳方法是什么?将每个标记从原始字符串中分离出来并一次搜索一个需要很长时间

这是我现在拥有的代码。尽管它或多或少有效,但速度不是很快

# The largest token is 8 ASCII chars long
'out' is the string with the final outputs
while len(data) != 0:
    length = 8
    while reverse_search(data[:length]) == None:#sorry THC4k, i used your code 
                                                #at first, but it didnt work out 
                                                #for this and I was too lazy to
                                                #change it
        length -= 1
    out += reverse_search(data[:length])
    data = data[length:]
4

1 回答 1

1

如果您尝试一次替换字符串,则可以使用字典:

translation = {'PRINT': '32', 'GOTO': '41'}
code = ' '.join(translation[i] if i in translation else i for i in code.split(' '))

这基本上是O (2|S|+(n*|dict|))。非常快。尽管内存使用量可能相当大。跟踪替换将允许您在线性时间内解决问题,但前提是您排除了查找先前替换的成本。总而言之,这个问题本质上似乎是多项式的。

除非python中有一个函数可以通过我不知道的字典翻译字符串,否则这似乎是最简单的放置方法。

事实证明

10 PRINT HELLO
20 GOTO 10

进入

10 32 HELLO
20 41 10

我希望这与您的问题有关。

于 2010-08-22T19:23:07.250 回答