python --冒泡排序
【问题描述】
小蓝最近学习了一些排序算法,其中冒泡排序让他印象深刻。
在冒泡排序中,每次只能交换相邻的两个元素。
小蓝发现,如果对一个字符串中的字符排序,只允许交换相邻的两个字符,
则在所有可能的排序方案中,冒泡排序的总交换次数是最少的。
例如,对于字符串 lan 排序,只需要 1 次交换。对于字符串 qiao 排序,
总共需要 4 次交换。
小蓝找到了很多字符串试图排序,他恰巧碰到一个字符串,需要 100 次交
换,可是他忘了吧这个字符串记下来,现在找不到了。
请帮助小蓝找一个只包含小写英文字母且没有字母重复出现的字符串,对
该串的字符排序,正好需要 100 次交换。如果可能找到多个,请告诉小蓝最短
的那个。如果最短的仍然有多个,请告诉小蓝字典序最小的那个。请注意字符
串中可以包含相同的字符。
分析:
假设完全逆序,设长度为n,采用冒泡排序则移动次数为 n*(n-1)/2,当n=15;移动次数105,移动次数大于100,又要求字典序最小,则把第六个字符移动到第一个位置,前五个字符后移一位。即:jonmlkihgfedcba
代码可以进行验证:
// An highlighted block
#冒泡排序
def <