51nod 1435 位数阶乘 (手动计算)
来源:互联网 发布:mac帧结构 编辑:程序博客网 时间:2024/06/05 11:18
题目:
1435 位数阶乘
题目来源: CodeForces
基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题
X是一个n位数的正整数 (x=a0a1…an−1)
现在定义 F(x)=∏i=0n−1(ai!) , 比如F(135)=1!*3!*5!=720.
我们给定一个n位数的整数X(至少有一位数大于1,X中可能有前导0),
然后我们去找一个正整数(s)符合以下条件:
1.这个数尽可能大,
2.这个数中不能含有数字0或1。
3.F(s)=F(x)
Input
每个测试数据输入共2行。
第一行给出一个n,表示x为中数字的个数。(1<=n<=15)
第二行给出n位数的正整数X(X中至少有一位数大于1)
Output
共一行,表示符合上述条件的最大值。
Input示例
4
1234
Output示例33222
这题纯手动解决,以为有规律,发现数字大了就没规律了。
解法:把15个9以内的阶乘分解成尽量多的2-9的阶乘。然后从大的数开始输出。
这题不管怎么分都是要从最大的素数因子开始的,要不然就不能分解。
我们能够想到的是2,3,5,7是没法再分小了的。 (想想7!怎么分,第一个7就没法分)
所以只有4,6,8,9四个数字的阶乘要分,
4分为:1个3!和2个2! 6分为:1个5!和1个3!
8分为:1个7!和3个2!
9分为:1个7!和2个3!和1个2!
这题就是这么暴力。
我刚开始以为任何大于1的自然数的阶乘都可以分成 任意个质数阶乘的积。
后来找到了反例(100! = 97!*98*99*100),分出来的3个数字没法拼成素数阶乘的积。
代码:
#include <iostream>#include <algorithm>#include <map>#include <vector>#include <set>#include <math.h>using namespace std;typedef long long ll;#define INF 2147483647//num[i] 表示 i! 的数量 int num[11]; int main(){ int n; string s; cin >> n >> s; for(int i = 0;s[i]; i++){ if(s[i] == '9'){ //9!可以分为 7!* (2*3!) * 2!。 num[7]++; num[3] += 2; num[2]++; }else if(s[i] == '8'){ //8! 可以分为 7!* (3*2!) num[7]++; num[2] += 3; }else if(s[i] == '6'){ //6! 可以分为 5! * 3! num[5]++; num[3]++; }else if(s[i] == '4'){ //4! 可以分为3! * (2*2!) num[3]++; num[2] += 2; }else{ //质数的阶乘不可分 num[s[i]-'0']++; } } for(int i = 9;i >= 2; i--){ while(num[i]--) cout << i; } cout << endl; return 0;}
- 51nod 1435 位数阶乘 (手动计算)
- 51nod 1435:位数阶乘
- 51nod-1435 位数阶乘
- 51nod 1435 位数阶乘
- 51nod 1435 位数阶乘
- 51 nod 1435 位数阶乘
- 51nod 1435 位数阶乘 (简单题)
- 51nod 1435 位数阶乘 (思维水题)
- 51nod 1435 位数阶乘 找规律
- 51Nod-1435-位数阶乘
- 51nod 1058 阶乘的位数
- 阶乘位数的计算
- 阶乘位数计算
- 51Nod关于n的阶乘的长度(斯特林公式近似计算阶乘)
- NEFU OJ26 计算阶乘位数
- nefu 26 计算阶乘位数
- hdu(1018)Big Number(阶乘位数的计算)
- HDU--1018--Big number!(计算阶乘结果的位数)
- 数组排序【值排序,值相同键排序】
- Atom 下运行 Node 时 NODE_ENV 默认变成 Production 的解决方法
- poj 1185 炮兵阵地 (状态压缩)
- 基于 Vue.js 的移动端组件库mint-ui
- windows默认编辑器打开bat文本内容没有换行
- 51nod 1435 位数阶乘 (手动计算)
- Physion(二维模型绘制软件) v1.2.0中文版下载附安装教程
- 洛谷 1869 愚蠢的组合数 Lucas定理 解题报告
- 将算法复杂度一步步进化到O(n)的最大子序列和的方法合集
- hdu4336 Card Collector
- 微信小程序项目源码
- 浅谈编码和乱码
- 基于服务的体系结构
- 切换 Python