51nod1057—N的阶乘—(大数阶乘)
输入N(1 <= N <= 10000)
输出N的阶乘
5
120 思路:按照乘法运算的规则进行模拟,声明一个数组ans,用来存运算后每一位的值。遍历2到n中的所有的数,每次都用这个数去和ans数组中的每个数相乘,并按乘法规则进位即可。
普通版代码:
//普通版
#include<iostream>
#include<cstring>
#include<cstdio>
#include<string>
#include<cmath>
#include<climits>
#include<algorithm>
#include<stack>
#include<queue>
#define eps 1e-7
#define ll long long
#define inf 0x3f3f3f3f
#define pi 3.141592653589793238462643383279
using namespace std;
int main()
{
int ans[],n; //ans数组用来储存结果
while(cin>>n)
{
memset(ans,,sizeof(ans));
int cnt = ,res,carry=; //cnt用来记录当前最高位是多少
ans[] = ;
for(int i=; i<=n; ++i) //遍历2-n中所有的数
{
for(int j=; j<cnt; ++j) //ans中的每个数都乘上i
{
res = ans[j]*i+carry; //这一位乘上 i 并加上上一位的进位数量
ans[j] = res%; //按乘法规则进行进位
carry = res/;
}
while(carry) //如果最高为还能进位,最高为就要加 1,一直循环到不能进位为止
{
ans[cnt++] = carry%;
carry /= ;
}
}
for(int i=cnt-; i>=; --i) //输出
printf("%d",ans[i]);
printf("\n");
}
return ;
}
但是,上面的代码还并不足以通过这一题,时间复杂度卡在了时间限制的边缘。我们可以对上面的代码进行一个简单但却精妙的优化。在上面的代码中,ans数组中的每个数仅仅只表示了一位,对于整型变量的范围来说,这显得有些浪费。于是乎,我们可以用ans数组中的每个元素来记录最终答案的多位,这样就可以缩短几倍的时间。
例如,在接下来的代码中,我用ans中的每个数来记录9位,这表示用1000000000代替10来进行进位操作。最后在输出的过程中,如果ans【i】=0,那我们实际上要输出九个0,因为每个位置记录了9位。 优化版代码:
//优化版:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<string>
#include<cmath>
#include<climits>
#include<algorithm>
#include<stack>
#include<queue>
#define eps 1e-7
#define ll long long
#define inf 0x3f3f3f3f
#define pi 3.141592653589793238462643383279
const ll MAXN = ; //用来代替10进位的MAXN
using namespace std;
int main()
{
ll ans[]; //用long long防止数据溢出
int n;
while(cin>>n)
{
ans[] = ;
ll res,carry = ,cnt = ;
for(int i=; i<=n; ++i)
{
for(int j=; j<cnt; ++j)
{
res = ans[j]*i + carry;
ans[j] = res % MAXN; //用MAXN进行进位操作
carry = res / MAXN;
}
while(carry)
{
ans[cnt++] = carry;
carry = ;
}
}
printf("%lld",ans[cnt-]); //首先输出最高位的元素,因为最高位的元素并不一定有9位
for(int i=cnt-; i>=; --i) //格式化输出剩下的元素
printf("%.9lld",ans[i]); // %.9的作用是如果数据大于9位,则正常输出,否则,不足9位将在高为上补 0
//如:%.3输出12,将会输出012,所以,上面的ans[i]中若位0,将输出000000000,防止位数丢失
cout<<endl;
}
return ;
}
当然,并不一定要用9位来进行记录,在确保不会导致long long数据溢出的情况下,也可以稍微比9大一些。
如果你选择用15位来记录,运算10000的阶乘时很有可能会溢出,因为15+4=19位,将会超过long long的范围。所以在不太确定的情况下,尽量使用较为保险的长度。
51nod1057—N的阶乘—(大数阶乘)的更多相关文章
- nyist28大数阶乘
http://acm.nyist.net/JudgeOnline/problem.php?pid=28 大数阶乘 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 我们 ...
- 大数阶乘(c语言)
大数阶乘.代码比较简单. #include<stdio.h> #include<string.h> #define MAXN 25000 // 如果你的阶乘N比较大,建议大一点 ...
- 【大数阶乘】NYOJ-28
大数阶乘 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 我们都知道如何计算一个数的阶乘,可是,如果这个数很大呢,我们该如何去计算它并输出它? 输入 输入一个整数 ...
- 大数阶乘 nyoj
大数阶乘 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 我们都知道如何计算一个数的阶乘,可是,如果这个数很大呢,我们该如何去计算它并输出它? 输入 输入一个整数 ...
- 【ACM】大数阶乘 - Java BigInteger实现
大数阶乘 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 我们都知道如何计算一个数的阶乘,可是,如果这个数很大呢,我们该如何去计算它并输出它? 输入 输入一个整数 ...
- nyoj___大数阶乘
http://acm.nyist.net/JudgeOnline/problem.php?pid=28 大数阶乘 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 我们都知 ...
- 大数阶乘(c++实现)
#include <iostream>using namespace std;#define N 1000int BigNumFactorial(int Num[], int n);voi ...
- HDU 1133 Buy the Ticket (数学、大数阶乘)
Buy the Ticket Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)To ...
- for循环计算某个数的阶乘、阶乘和及其倒数的阶乘和
//4的阶乘 int jc = 4; //定义一个变量用来代表要计算的数值 long jd =1; //定义最终输出的阶乘 for(int i = 1; i <= jc;i++) //定义循环加 ...
随机推荐
- 转-oracle中比较两表表结构差异和数据差异的方法
oracle中比较两表表结构差异和数据差异的方法 原作者:li2008xue2008ling 出处:http://blog.csdn.net 在工作中需要完成这么一个需求:比较两个表的表 ...
- js基础篇(dom操作,字符串,this等)
首先我们来看这样一道题 <div id='foo' class='aa bb cc'></div>写出如何判断此div中是否含有aa(注:aa成立,aaa不成立) 首先,我们一 ...
- 黄聪:VS2010启动程序提示文件加载 使用 简体中文(GB2312)编码加载文件解决办法
vs2010 错误提示框:文件加载 使用 简体中文(GB2312)编码加载文件C:\Users\Administrator\AppData\Local\Temp\nxhgjasi.5au \Temp\ ...
- 在NOILINUX下的简易VIM配置
位置:/etc/vim/vimrc 建议使用gedit来进行配置.即使用命令:sudo gedit /etc/vim/vimrc set mouse=a " Enable mouse usa ...
- (转)powerdesigner 生成sql脚本使用的设置
本文转载自:http://blog.163.com/lizhihaoo@126/blog/static/103121661201036171115/ 1. 生成sql脚本的时候,提示"con ...
- [转]MVC 经验总结_序
<appSettings> <add key="vs:EnableBrowserLink" value="false"/> </a ...
- tcpdump查看某个端口数据
tcpdump -i eth0 -nn -A port tcpdump src
- Unix socket的准备(一)
套接字地址结构 套接字编程中,五元组是广为人知的. (host_ip, host_port, target_ip, target_port, protocol). 其中 ip 和 port 就是由套接 ...
- go run helper
# go run helper -a :强制编译相关代码,不论编译代码是否最新 -n :打印编译过程需要用到的命令,但不真正执行他们 -p n :并行编译,n为并行的数量 -v :列出被编译的代码包的 ...
- CentOS 7 调整 home分区 扩大 root分区
总体过程: 把/home内容备份,然后将/home文件系统所在的逻辑卷删除,扩大/root文件系统,新建/home ,恢复/home内容 1.查看分区 df -h 2.备份home分区文件 tar c ...