作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试编写一个函数,该函数将字符串 s
作为输入并返回 s
中按字母顺序排列的那些子字符串的列表。例如,s = 'acegibdh'
应该返回 ['acegi', 'bdh']
。
这是我想出的代码:
s = 'acegibdh'
ans = []
subs = []
i = 0
while i != len(s) - 1:
while s[i] < s[i+1]:
subs.append(s[i])
i += 1
if s[i] > s[i-1]:
subs.append(s[i])
i += 1
subs = ''.join(subs)
ans.append(subs)
subs = []
print ans
由于 i+1 测试超出索引范围,字符串的最后一个字母一直有问题。我花了很长时间来修补它,试图想出一种方法来避免这个问题。有谁知道如何做到这一点?
最佳答案
为什么不将第一个字母硬编码为 ans
,然后只处理字符串的其余部分?您可以只遍历字符串本身而不是使用索引。
>>> s = 'acegibdh'
>>> ans = []
>>> ans.append(s[0])
>>> for letter in s[1:]:
... if letter >= ans[-1][-1]:
... ans[-1] += letter
... else:
... ans.append(letter)
...
>>> ans
['acegi', 'bdh']
关于python - 如何返回字母子串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30922659/
我遇到问题,因为我的代码返回的结果与解决方案代码不同。我发现区别在于过滤功能。 练习链接:http://eloquentjavascript.net/code/#5.2 我的过滤功能: ancestr
我是一名优秀的程序员,十分优秀!