蓝桥杯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✨


相关推荐
ZTLJQ1 天前
序列化的艺术:Python JSON处理完全解析
开发语言·python·json
H5css�海秀1 天前
今天是自学大模型的第一天(sanjose)
后端·python·node.js·php
阿贵---1 天前
使用XGBoost赢得Kaggle比赛
jvm·数据库·python
无敌昊哥战神1 天前
【LeetCode 257】二叉树的所有路径(回溯法/深度优先遍历)- Python/C/C++详细题解
c语言·c++·python·leetcode·深度优先
李昊哲小课1 天前
第1章-PySide6 基础认知与环境配置
python·pyqt·pyside
2401_894241921 天前
用Pygame开发你的第一个小游戏
jvm·数据库·python
Zzzz_my1 天前
正则表达式(RE)
pytorch·python·正则表达式
天天鸭1 天前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
setmoon2141 天前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
2401_833197732 天前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python