蓝桥杯3527阶乘的和 | 组合数学

写在前面的话

昨天的蓝桥杯每日一题 奇怪的数 用python写太难了,甚至题解的优化处理也只能得70分(后几个TLE了),但是C++写 不优化的6层for循环+后4位复用 可以直接过。(雾)

题目传送门


这个题目的思路是对Ai排序后,记录每个Ai出现的次数dic[Ai]。显然最小的A0满足m。每次遍历dic,如果m对应的Ai出现的次数是Ai+1的倍数,那么将其并入dic[Ai+1],同时m++。当m无法满足次数的倍数关系时m值即为所求。


python 复制代码
from collections import defaultdict
n = int(input())
ai = list(map(int, input().split()))
ai.sort()
m = ai[0]
dic = defaultdict(int)	# 因为python的dict()不支持类似C++中map的运算操作,所以引入defaultdict

for it in ai:
    dic[it] += 1

while True:
    x = dic[m]
    if x %(m + 1) != 0:
        break
    dic[m+1] += x//(m+1)
    m += 1

print(m)

END✨


相关推荐
qq_34229582几秒前
CSS如何根据父级容器宽度调整子项_利用容器查询container选择器css
jvm·数据库·python
2301_80387561几秒前
Go语言怎么做分布式缓存_Go语言分布式缓存教程【经典】
jvm·数据库·python
qq_206901391 分钟前
CSS如何处理CSS颜色模式不兼容_通过fallback定义标准颜色值
jvm·数据库·python
2301_796588501 分钟前
SQL利用窗口函数实现轻量级报表设计_实战技巧
jvm·数据库·python
Omics Pro2 分钟前
癌症亚型分类新型多组学整合框架
大数据·人工智能·python·算法·机器学习·分类·数据挖掘
weixin_568996063 分钟前
Python开发Flask项目如何部署到云服务器_使用Fabric自动化发布脚本
jvm·数据库·python
m0_596406375 分钟前
Python中正确声明、重新赋值并安全使用None变量的完整指南
jvm·数据库·python
Word码5 分钟前
QQ音乐自动化测试实战指南
python·功能测试·测试工具·pycharm·集成测试
m0_716430077 分钟前
实现 Flex 容器内子元素自适应高度并启用自动滚动
jvm·数据库·python
weixin_381288187 分钟前
c++怎么在写入文本文件时自动将所有的制表符统一转换为四格空格【实战】
jvm·数据库·python