2020年第十一届蓝桥杯省赛Python组(真题+解析+代码):排序

1 真题

小蓝最近学习了一些排序算法,其中冒泡排序让他印象深刻. 在冒泡排序中,每次只能交换相邻的两个元素。 小蓝发现,如果对一个字符串中的字符排序,只允许交换相邻的两个字符, 则在所有可能的排序方案中,冒泡排序的总交换次数是最少的。 例如, 对于字符串lan排序,只需要1次交换。对于字符串qiao排序, 总共需要4次交换。 小蓝找到了很多字符串试图排序,他恰巧碰到一个字符串,需要100次交换,

可是他忘了把这个字符串记下来,现在找不到了。 请帮助小蓝找一个只包含小写英文字母且没有字母重复出现的字符串,对该串的字符排序,正好需要100次交换。如果可能找到多个,请告诉小蓝最短的那个。如果最短的仍然有多个,请告诉小蓝字典序最小的那个。


2 解析

难度系数:⭐

考察题型:数论

涉及知识点:冒泡排序 时间复杂度

思路分析:

整体思路就是不断缩小答案的范围。

1、先看题目给的条件:包含小写英文字母没有字母重复出现,那就是在a~z里面找。

2、冒泡排序的排序交换次数有个公式:count=(n*(n-1)) / 2

题目要求交换100次,n一个个代入公式试试看,发现n=15时,count=105次,

说明最多有15个小写英文字母。

3、然后题目要求字典序最小(字典序最小就是指 a,b,c,d的顺序最小)

那就是abcdefghijklmno这15个字母。

如果倒着写:onmlkjihggedcba 它们交换成正序最多要105次。

4、那题目要求100次,那咋办呢?

手动先给它换5次,105次就变成100次了。

o向后换5次,把j换到最前面,答案就是:jonmlkihgfedcba.


3 代码

#代码验证:判断交换次数是否为100次?
s=list("jonmlkihgfedcba")
cnt=0
#冒泡排序
for i in range(len(s)-1):
    for j in range(len(s)-1-i):
        if s[j]>s[j+1]:
            s[j],s[j+1]=s[j+1],s[j]
            cnt+=1
print(cnt)

     我写的是关于蓝桥杯的系列题解,感谢关注我的朋友们,我会持续输出高质量文章   蓝桥杯python组十一届省赛真题+解析+代码(通俗易懂版)_编程有了思路-CSDN博客小蓝要为一条街的住户制作门牌号。这条街一共有 2020 位住户,门牌号从 1 到 2020 编号。小蓝有一个数字矩阵,里面只包含数字 0 和 2。小蓝每天都锻炼身体。正常情况下,小蓝每天跑 1 千米。如下图所示,小明用从1开始的正整数“蛇形”填充无限大的矩阵。https://blog.csdn.net/m0_55148406/article/details/122863264?spm=1001.2014.3001.5502

你可能感兴趣的:(蓝桥杯,python,算法,职场和发展,排序算法)