4-10 阶乘计算升级版 (20分)
2015-10-14 23:08
330 查看
本题要求实现一个打印非负整数阶乘的函数。
函数接口定义:
void Print_Factorial ( const int N );其中
N是用户传入的参数,其值不超过1000。如果
N是非负整数,则该函数必须在一行中打印出
N!的值,否则打印“Invalidinput”。
裁判测试程序样例:
#include <stdio.h>void Print_Factorial ( const int N );int main(){int N;scanf("%d", &N);Print_Factorial(N);return 0;}/* 你的代码将被嵌在这里 */
输入样例:
15
输出样例:
1307674368000
#include <stdio.h>void Print_Factorial ( const int N );int main(){int N;scanf("%d", &N);Print_Factorial(N);return 0;}void Print_Factorial ( const int N ){if(N>0&&N<=12){int i;long int M=1;for(i=2;i<=N;i++){M=M*i;}printf("%ld\n",M);}else if(N>12&&N<=1000){int Num[3001]={0};int i,j,k,n;k=1;n=0;Num[0]=1;int temp;for(i=2;i<=N;i++){for(j=0;j<k;j++){temp=Num[j]*i+n;Num[j]=temp%10;n=temp/10;}while(n!=0){Num[k]=n%10;k++;n=n/10;}}for(i=k-1;i>=0;i--){printf("%d",Num[i]);}}else if(N==0)printf("1\n");elseprintf("Invalid input\n");}[/code]
相关文章推荐
- Oracle 简单操作手册
- [bzoj2226][SPOJ5971]LCMSUM
- 进程&线程小结
- worker_pool的例子
- 浅析c++中的类型转换--const_cast
- IndexedDB: 浏览器里内置的数据库简介
- Application.mk
- 浅析c++中的类型转换--const_cast
- 算法(一)求链表中的倒数第K 个结点
- ENVI遥感影像自然真彩色增强方法
- 实现基于Task的异步模式
- 海思Hi3518内核编译过程中问题点记录
- ndk-build
- 地图定位异常问题
- struts2标签Tags的用法
- Spring官网改版后下载
- 新版WampServer项目路径前面没有localhost
- 饭碗是要靠抢的
- Sql Server 分页查询
- C++文件(夹)选择对话框