当前位置: 首页 > news >正文

包子凑数——蓝桥杯真题Python

包子凑数

在这里插入图片描述

输入输出样例
示例 1

输入

2
4
5

输出

6

样例说明

凑不出的数目包括:1, 2, 3, 6, 7, 11。

示例 2

输入

2
4
6

输出

INF

样例说明

所有奇数都凑不出来,所以有无限多个

运行限制
  • 最大运行时间:1s
  • 最大运行内存: 256M

最大公约数

最大公约数:Greatest Common Divisor,GCD,指两个或多个整数共有约数中的最大值。

计算方法:

  1. 质因数分解法:将各数分解为质因数,取共有质因数的最小幂次乘积。

    例如,求36和48的GCD:

    36=2^2 * 32,48=24 * 3^1

    GCD=22*31=12

  2. 辗转相除法(欧几里得算法):基于定理 gcd (a,b)=gcd (b,a mod b),迭代至余数为零。

    例如,求 1071 和 462 的 GCD:

    1071 ÷ 462 = 2(余 147)→ gcd (462,147)

    462 ÷ 147 = 3(余 21)→ gcd (147,21)

    147 ÷ 21 = 7(余 0)→ GCD 为 21

裴蜀定理
  1. 定理内容:对于多个整数,若其GCD为d,则它们线性组合的所有可能结果均为d的倍数。
  2. 无限不可凑数判定:若所有整数的GCD大于1,则只能凑出d的倍数,此时就有无限多 无法凑出的数目,如GCD=2,那么所有的奇数都无法凑出。
  3. 有限不可凑数判定:若GCD为1,则存在一个最大不可凑数M,超过M的所有数均可被凑出,
解题步骤
  1. 首先输入n和数组A
  2. 情况一:若数组A中包含1,那么说明任何数都能凑,打印0.
  3. 情况二:GCD!=1,则说明有无数个无法凑出的数,打印INF。
  4. 情况三:GCD==1,则进入动态规划步骤。
import math
def main():
    n = int(input())
    A = [[int(input())] for _ in range(n)]
    if 1 in A:
        print("0")
      	return
    g = A[0]
    for a in A:
        g = math.gcd(a,g)
    if g != 1 :
        print("INF")
        return
    else :
        maxSize = 10000
        dp = [False] * (maxSize + 1)
        dp[0] = True
        for i in range(1, maxSize+1):
            if dp[i]:
                for a in A:
                    if i+a < maxSize+1:
                        dp[i+a] = True
        result = 0
        for i in dp:
            if i == False:
                result += 1
        print(result)
        return
    
if __name__ == "__main__":
    main()

相关文章:

  • Eclipse安装和配置环境教程包含下载、安装、汉化(附安装包)
  • 大小端存储的概念和判断
  • 2025年- G18-Lc92-169. 多数元素-java版
  • SQLmap 使用指南:开启安全测试高效之旅
  • React 高阶组件(HOC)
  • 【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(六) -> CSS动画
  • 【JavaScript】《JavaScript高级程序设计 (第4版) 》笔记-Chapter24-网络请求与远程资源
  • Spring Framework测试工具MockMvc介绍
  • 小程序类目调整汇总公告
  • Springer独立出版 EI检索 | 2025年第三届绿色建筑国际会议(ICoGB 2025)
  • 【SRC实战】修改金币数量实现财富自由
  • ARM Coretex-M核心单片机(STM32)找到hardfault的原因,与hardfault解决方法
  • rk3588增加独立分区
  • 【自学笔记】Vue基础知识点总览-持续更新
  • 智能运维语义标注体系技术框架与工程化实践
  • 【嵌入式原理设计】实验六:倒车控制设计
  • 深入Linux序列:进程的终止与等待
  • Python Cookbook-2.13 使用C++的类iostream语法
  • SSD网络预测与训练阶段总结
  • mysql多表查询
  • 春秋航空:如果供应链持续改善、油价回落到合理水平,公司补充运力的需求将会增长
  • A股三大股指低收:银行股再度走强,两市成交11920亿元
  • 习近平同俄罗斯总统普京举行会谈
  • 对话哭泣照被恶意盗用成“高潮针”配图女生:难过又屈辱
  • 小米回应SU7Ultra排位模式限制车辆动力:暂停推送更新
  • 金融监管总局:做好2025年小微企业金融服务工作