求阶乘以及求各项阶乘和问题
来源:互联网 发布:香蕉网络电视免费 编辑:程序博客网 时间:2024/06/01 23:44
下午做了一道笔试题,试求各项阶乘和的问题,也就是求 : 1! + 2! + ... + n!。
一开始没什么思路,那就想着暴力求。。。就是从1~n,求每一项的阶乘,再求和,效率肯定低,当时脑子浑噩,脑子里想着这样肯定是有重复相乘的,但就是没能想出优化的T_T
好吧,那就先来暴力求解吧。关于求阶乘的,用了递归求解(关键当时递归还给漏了个n,还是渣啊),想到可能会数很大,就暂时用了long型
/** * 求n的阶乘 * @param n * @return */ long getFactorial(int n) {if(n == 0 || n == 1)return 1;return n*getFactorial(n-1);}再从1~n遍历求和
long getFactorialSum(int n) {if(n == 1)return 1;long result = 1;for (int i = 2; i <= n; i++) {result += getFactorial(i);}return result;}应该是可以解决了。。。。
但是刚交了卷,出来后再想了一下,竟然想通了,zz啊。。。
发现求阶乘: n! = n * (n-1)!,而求和中我们完全可以从底层开始求起,并用一个变量记录当前的阶乘项,每轮把它乘上i,不就相当于就得 n!了,再把这项加到和种就可以了,完全不用单独去求阶乘,这也是基于了所谓的动态规划,把前面的结果拿来用,不用重复计算。上代码
/** * 求: 1! + 2! + ... + n! * @param n * @return */long getFactorialSum(int n) {if(n == 1)return 1;long result = 1;long currentFactorial = 1; //记录第i项阶乘结果的for (int i = 2; i <= n; i++) {currentFactorial *= i ;result += currentFactorial;}return result;}
阅读全文
0 0
- 求阶乘以及求各项阶乘和问题
- 21 求阶乘问题
- 求阶乘的和
- 求阶乘和
- 求阶乘和
- 求阶乘和
- 【1031】求阶乘和
- 关于求阶乘和的问题
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘
- 求阶乘:
- 51nod 1509 加长棒 组合数学(隔板法)
- Pix4D.Pix4Dmapper.Pro.v2.0.104.MacOSX 1CD(无人机数据处理软件)
- Jenkins 项目配置里缺少了 触发远程构建 (例如,使用脚本) Trigger builds remotely 选项的解决办法
- 【安全牛学习笔记】SHODAN
- Linux 查看PCI设备命令---lspci
- 求阶乘以及求各项阶乘和问题
- 2017 ACM-ICPC 亚洲区-banana
- 博客大转战
- 系统管理员的修炼宝典
- Python内置函数详解
- 剑指offer部分题目整理
- ASCII码对照表
- Android 读取本地图片的缩略图
- 静态,构造方法和super