计数排序的核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数。

def countSort(arr):      output = [0 for i in range(256)]      count = [0 for i in range(256)]      ans = ["" for _ in arr]      for i in arr:        count[ord(i)] += 1      for i in range(256):        count[i] += count[i-1]      for i in range(len(arr)):        output[count[ord(arr[i])]-1] = arr[i]        count[ord(arr[i])] -= 1      for i in range(len(arr)):        ans[i] = output[i]    return ans  


arr = "wwwrunoobcom"

ans = countSort(arr)

print ( "字符数组排序 %s"  %("".join(ans)) )

执行以上代码输出结果为:

符数组排序 bcmnoooruwww


来源:Python学习网