2020第十一届蓝桥杯省赛python真题详解(一)

简介: 2020第十一届蓝桥杯省赛python真题详解

试题A:门牌制作


42478952d9674521aff35320756482dd.png


s = 0
for i in range(1,2021):
    s += str(i).count('2')
print(s)
# 624


试题B:寻找2020

4bdd3763610a45b3bfd50e10eeecc31e.png

nums = [[2, 2, 0, 0, 0, 0],
        [0, 0, 0, 0, 0, 0],
        [0, 0, 2, 2, 0, 2],
        [0, 0, 0, 0, 0, 0],
        [0, 0, 0, 0, 2, 2],
        [0, 0, 2, 0, 2, 0],
        ]
n = 0
for i in range(len(nums)):
    for j in range(len(nums[0])):
        if j+4 <= len(nums[0]):
            a = nums[i][j:j+4]
            if a == [2,0,2,0]:
                n+=1
        if i+3<len(nums):
            b = nums[i][j]*1000+nums[i+1][j]*100+nums[i+2][j]*10+nums[i+3][j]
            if b == 2020:
                n+=1
        if i+3<len(nums) and j+3 < len(nums[0]):
            c = nums[i][j]*1000+nums[i+1][j+1]*100+nums[i+2][j+2]*10+nums[i+3][j+3]
            if c == 2020:
                n+=1
print(n)


试题C:跑步锻炼

800f470532a34440bccad73374edc86a.png

import datetime
a = datetime.date(2000,1,1)
b = datetime.date(2020,10,2)
num = 0
while True:
    if a == b:
        break
    if a.day == 1:
        num+=2
        a = a+datetime.timedelta(days=1)
        continue
    if a.isoweekday() == 1:
        num+=2
        a = a + datetime.timedelta(days=1)
        continue
    num+=1
    a = a + datetime.timedelta(days=1)
print(num)
# 8879


试题D:蛇形填数

b7b24fb6e6534fd391421c02ffeea107.png

# 代码运行
lst = [[] for i in range(40)]
num = 1
lst[0].append(1)
for i in range(2, 40):
    if i % 2 == 0:
        for j in range(i):
            num += 1
            lst[j].append(num)
    else:
        for j in range(i):
            num += 1
            lst[i - j - 1].append(num)
for i in range(len(lst)):
    print(i + 1, lst[i])
print(lst[19][19])


试题E: 排序

15ee53d682b24c278f00883c039584fd.png

# 当所有的字符全全部倒序的时候重新排序的次数就越多,所用的字符就越少
# 又因为要求字典序最小,所以字母应该是前n位
# 由于冒泡排序的特征,完全倒序的情况下,交换的次数是(n-1)+(n-2)......2+1
# 算出当有15字符完全倒序的时候为,105,所以,只需要在此基础上稍加修改即可,
# 又因为需要保证字典序最小,即字符串的第一个字目应该尽量的小,所以将j前提5个字符
# 'abcdefghijklmno'
# print('jonmlkihgfedcba')


试题F:成绩统计


2ebb1cdc1f4647a2b9a87d67259563d6.png

n = int(input())
y = 0
j = 0
for i in range(n):
    num = int(input())
    if num >= 85:
        y+=1
    if num >=60:
        j +=1
print('{:.0f}%'.format((j/n)*100))
print('{:.0f}%'.format((y/n)*100))


相关文章
|
存储 索引 Python
蓝桥杯系列2——python基本语法
蓝桥杯系列2——python基本语法
108 0
|
2月前
|
Python
蓝桥杯练习题(一):Python组之入门训练题
这篇文章是关于蓝桥杯Python组的入门训练题,包括Fibonacci数列、圆的面积、序列求和和A+B问题的具体代码实现和样例输出。
139 0
|
2月前
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
蓝桥杯Python编程练习题的集合,涵盖了从基础到提高的多个算法题目及其解答。
109 3
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
|
2月前
|
人工智能 Python
蓝桥杯练习题(四):Python组之历届试题三十题
关于蓝桥杯Python组历届试题的三十个练习题的总结,包括题目描述、输入输出格式、样例输入输出以及部分题目的解题思路和代码实现。
42 0
蓝桥杯练习题(四):Python组之历届试题三十题
|
2月前
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(二):Python组之基础练习三十题
蓝桥杯Python编程练习题的集合,包含了三十个不同难度的编程题目,覆盖了基础语法、数据结构和算法等领域。
43 0
|
7月前
|
索引 Python 容器
【备战蓝桥杯】探索Python内置标准库collections的使用
【备战蓝桥杯】探索Python内置标准库collections的使用
100 1
|
7月前
|
开发者 Python
【备战蓝桥杯】如何使用Python 内置模块datetime去计算我与CSDN相遇的天数
【备战蓝桥杯】如何使用Python 内置模块datetime去计算我与CSDN相遇的天数
72 1
|
7月前
|
算法 测试技术 编译器
蓝桥杯-02-python组考点与14届真题
蓝桥杯-02-python组考点与14届真题
|
7月前
|
Python
第十三届蓝桥杯B组python(试题A:排列字母)
第十三届蓝桥杯B组python(试题A:排列字母)
67 0
|
7月前
|
人工智能 算法 测试技术
第十四届蓝桥杯第三期模拟赛 【python】(二)
第十四届蓝桥杯第三期模拟赛 【python】(二)