我正在写一个函数来递增3个字母(a-z)的字符串。例如:
输入: AAA
输出:BAA在Python中递增字符串
输入: ZBA
输出:ACA
所以顺序如下
aaa
baa
...
zaa
aba
bba
cba
...
zba
aca
bca
cca
...
zca
ada
...
zzz
aaa
我写了下面的f结next_code()
和它的作品,但我想知道是否有实现它,而不是通过个别字母串在循环更优雅的方式:
# 0 = a; 25 = z
def digit_to_char(digit):
return chr(ord('a') + digit)
# a = 0; z = 25
def char_to_digit(char):
return ord(char)-ord('a')
def next_code(code):
# if used up all codes, loop from start
if code == 'zzz':
return next_code('aaa')
else:
code = list(code)
# loop over letters and see which one we can increment
for (i, letter) in enumerate(code):
if letter == 'z':
# go on to the next letter
code[i] = 'a'
continue
else:
# increment letter
code[i] = digit_to_char(char_to_digit(letter) + 1)
return ("".join(code))
break
print (next_code('aab'))
很好的回答...你为这个家伙覆盖了如此多的基地+1从我:) –
@JoranBeasley:TIMTOWTDI? :-)我喜欢找到他们。我从Perl开始。 – ShadowRanger
TSBO - APOO - OWTDI:P(lol) –