【数学推理】蓝桥杯第十四届---阶乘的和

题目描述

给定 n 个数 ,问能满足 m! 为 的因数的最大的 m 是多少。其中 m! 表示 m 的阶乘,即 1 × 2 × 3 × · · · × m。

输入格式

输入的第一行包含一个整数 n 。

第二行包含 n 个整数,分别表示 Ai,相邻整数之间使用一个空格分隔。

输出格式

输出一行包含一个整数表示答案。

样例输入

复制代码
3
2 2 2

样例输出

复制代码
3

提示

对于 40% 的评测用例,n ≤ 5000 ;

对于所有评测用例,1 ≤ n ≤ 10^5 1 ≤ Ai ≤ 10^9 。


(a!+b!+c!)(a<b<c) ,假设 b!是(a!+b!+c!)的最大因数那么一定是个小数(因为一定是一个小数,一定是整数),所以(a!+b!+c!)的最大因数一定是a!,如果有(a+1)个a!,那么 a!+a!+...+a!=(a+1)*a!=(a+1)! ,(如样例中的 2!+2!+2!=3*2!=3! )。


cpp 复制代码
#include<iostream>
#include<algorithm>
#include<unordered_map>
using namespace std;
#define int long long
const int N=1e5+10;
unordered_map<int,int> mp;
signed main(){
	int n;
	cin>>n;
	int minv=1e9+10;
	for(int i=1;i<=n;i++){
		int x;cin>>x;
		mp[x]++;
		minv=min(minv,x);
	}
	while(mp.count(minv)){
		int t=mp[minv]/(minv+1);
		int k=mp[minv]%(minv+1);
		if(k!=0) break;
		mp[minv+1]+=t;
		minv++;
	}
	cout<<minv<<endl;
	return 0;
}
相关推荐
chao1898447 小时前
MATLAB 实现声纹识别特征提取
人工智能·算法·matlab
zhishidi7 小时前
推荐算法之:GBDT、GBDT LR、XGBoost详细解读与案例实现
人工智能·算法·推荐算法
货拉拉技术7 小时前
货拉拉RAG优化实践:从原始数据到高质量知识库
数据库·算法
测试界茜茜7 小时前
独立搭建UI自动化测试框架分享
自动化测试·软件测试·功能测试·程序人生·ui·职场和发展
AKDreamer_HeXY7 小时前
ABC434E 题解
c++·算法·图论·atcoder
罗湖老棍子7 小时前
完全背包 vs 多重背包的优化逻辑
c++·算法·动态规划·背包
TL滕7 小时前
从0开始学算法——第四天(题目参考答案)
数据结构·笔记·python·学习·算法
potato_may8 小时前
C++ 发展简史与核心语法入门
开发语言·c++·算法
Liangwei Lin8 小时前
洛谷 P1443 马的遍历
数据结构·算法
老鱼说AI8 小时前
算法基础教学第二步:数组(超级详细原理级别讲解)
数据结构·神经网络·算法·链表