排序
【问题描述】
小蓝最近学习了一些排序算法,其中冒泡排序让他印象深刻。
在冒泡排序中,每次只能交换相邻的两个元素。
小蓝发现,如果对一个字符串中的字符排序,只允许交换相邻的两个字符,则在所有可能的排序方案中,冒泡排序的总交换次数是最少的。
例如,对于字符串 lan 排序,只需要 1 次交换。对于字符串 qiao 排序,总共需要 4 次交换。
小蓝找到了很多字符串试图排序,他恰巧碰到一个字符串,需要 100 次交换,可是他忘了吧这个字符串记下来,现在找不到了。
请帮助小蓝找一个只包含小写英文字母且没有字母重复出现的字符串,对该串的字符排序,正好需要 100 次交换。如果可能找到多个,请告诉小蓝最短的那个。如果最短的仍然有多个,请告诉小蓝字典序最小的那个。请注意字符串中可以包含相同的字符。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个只包含小写英文字母的字符串,在提交答案时只填写这个字符串,填写多余的内容将无法得分。
只有逆序的时候交换次数才会最多且位数最小,想到这个就好办了
照着100次感觉一个位数,代进去试,我一开始感觉10位也就是jihgfedcba,交换次数是45,那就继续往下感觉呗
就可以得到15位的时候离100次最接近了,是105次,那多出来这五次怎么办呢
那就要想办法把这多换的5次还回去
题目要求要字典序最小,怎么改变能让字典序最小呢?
当然是改变最大的那位数也就是第一位,当他最小,我们整个字符串的字典序当然也最小了
onmlkjihgfedcba,把距离第一位五个距离的j换到第一位,相当于他后面的onmlk在冒泡排序的时候都可以少交换一次了
这个实在想不明白的话,就是知道改变第一位,让第一位尽量小,然后一个个往里试嘛
#答案jonmlkihgfedcba
#冒泡排序
a=list(input().split())
print(a)
count=0
for j in range(len(a)-1):
for i in range(len(a)-1):
if a[i]>a[i+1]:
x=a[i]
a[i]=a[i+1]
a[i+1]=x
count+=1
print(a,count)
这个思路要更科学一些
(1条消息) 蓝桥杯Java 试题 E: 排序_罡罡同学的博客-CSDN博客https://blog.csdn.net/m0_46625346/article/details/112920576