问题在于,我正在使用sorted
函数来排列字母数字字符串列表。所述字符串必须以字母分隔。
例如:sortqns(['s1q1', 's10q1', 's1q2', 's10q10', 's10q2'])
def cmpqn(a, b):
if len(a) > len(b):
return 1
if len(a) < len(b):
return -1
if len(a) == len(b):
return 0
def sortqns(qnlist):
new = sorted(qnlist, cmp=cmpqn)
return new
返回['s1q1', 's1q2', 's10q1', 's10q2', 's10q10']
我的问题是排序第二位数字:
sortqns(['s12q1', 's1q2', 's1q1'])
Returns ['s1q2', 's1q1', 's12q1']
而不是:
Returning ['s1q1', 's1q2', 's12q1']
在第一个例子中,如果前两个项目也被交换,我想要的回报将会关闭。
答案 0 :(得分:5)
列表中的排序算法是稳定的。稳定的排序算法使用相同的密钥保持记录的相对顺序。因此,在你的代码中,当两个元素具有相同的长度时,它们将在结果中出现维持其相对顺序。
我认为以下解决方案很有帮助。
def sortqns(qnlist):
return sorted(qnlist, key = lambda x: (len(x), x))