14届蓝桥杯 python B组 填空题 2023

本文介绍了一种编程方法,通过定义`check`函数,利用暴力破解的方式在给定范围内(12345678到98765432)检查数字是否按照3-2-0-2的顺序出现,以判断是否存在2023。
摘要由CSDN通过智能技术生成

1. 2023

这是选择题,最后只需要填答案。

这里使用暴力破解。使用 // 和 % 去获取数字的每一位而不是转化为字符串再根据索引去获取,更简洁一些。 

- x // 10 : 获取去掉最后一个数字的数值 如 123 // 10 = 12

- x%10:获取最后一个数字 如 123%10 = 3

如果能从末尾完整的按顺序 找到 3 -> 2 -> 0 -> 2 则这串数字中按照正相关顺序一定有 “2023”

- 按照题意,如果某个数不能找到“2023”,则结果 + 1


def check(x):
    target = [3, 2, 0, 2]
    k = 0
    while x > 0:
        i = x%10
        x = x//10
        if i == target[k]:
            k += 1
        if k == 4:return 0
    return 1


res = 0
for i in range(12345678,98765432+1):
    res += check(i)
print(res)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值