HDU 1042 N!(高精度阶乘、大数乘法)

N!

Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)
Total Submission(s): 100274    Accepted Submission(s): 30006

 

Problem Description

 

Given an integer N(0 ≤ N ≤ 10000), your task is to calculate N!

 

Input

 

One N in one line, process to the end of file.

 

Output

 

For each N, output N! in one line.

 

Sample Input

1
2
3

Sample Output

1
2
6

题目大意与分析

题目意思很简单,就是求阶乘,我们可以看到这是一个大数乘小数的问题,因为N是小于10000的,所以每次都是乘一个int可以存下的数,但是另一个乘数可能是一个大数,所以称之为大数乘小数。

那么如何计算呢:

用字符数组存大数,然后和大数加法很像,与竖式计算一样的原理,大数的每一位都要去乘这个小数,模10是当前位上的值,除以10是进位。

与大数加法略有不同的是,大数要倒着存,比如123 就要anss[1]=3,anss[2]=2,anss[3]=1,这是因为加法的进位只会进一位,乘法进位可能会进好几位,倒着存容易处理。

代码

#include<bits/stdc++.h>using namespace std;
int anss[1000000],n,cnt,i,j,k,temp;
int main()
{while(scanf("%d",&n)!=EOF){memset(anss,0,sizeof(anss)); anss[1]=1;cnt=1;                            //记录当前结果长度 for(i=1;i<=n;i++){k=0;                        //记录进位 for(j=1;j<=cnt;j++){temp=(anss[j]*i+k)%10;k=(anss[j]*i+k)/10;anss[j]=temp;} while(k){anss[++cnt]=k%10;k=k/10;}}for(i=cnt;i>=1;i--)printf("%d",anss[i]);printf("\n");}
}

 

 

 

转载于:https://www.cnblogs.com/dyhaohaoxuexi/p/11327425.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/276866.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

设计模式学习笔记九:原型模式(Prototype Pattern)

1&#xff0e;概述 意图&#xff1a;我们将已经存在的对象作为原型&#xff0c;用户可以通过复制这些原型创建新的对象。 使用场合&#xff1a;当一个系统应该独立于产品的创建、构造和表示时&#xff0c;可以使用原型模式。在原型模式中&#xff0c;产品的创建和初始化…

Centos7上安装docker

步骤&#xff1a;1、Docker 要求 CentOS 系统的内核版本高于 3.10 &#xff0c;查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker 。通过 uname -r 命令查看你当前的内核版本2、使用 root 权限登录 Centos。确保 yum 包更新到最新。 &#xff08;这个可能需要几分钟的…

pythonista3安装stash_Pythonista下stash安装教程

前言 “StaSh is a serious attempt to implement a Bash-like shell for Pythonista.” StaSh是一个Pythonista环境下的仿shell程序&#xff0c;Sta来自于Pythonista的后三个字母&#xff0c;Sh即shell缩写。除了能完成shell的基本功能外&#xff0c;最主要的功能还有实现pip安…

通过java类的反射机制获取类的属性类型

import java.lang.reflect.Field;import java.lang.reflect.Method; Class<?> clsClass.forName(className);//通过类的名称反射类//Class<?> cls Object.getClass();Field field cls.getDeclaredField("name");//根据属性名称获取单个属性if (field…

建立合理的索引提高SQL Server的性能

在应用系统中,尤其在联机事务处理系统中,对数据查询及处理速度已成为衡量应用系统成败的标准。而采用索引来加快数据处理速度也成为广大数据库用户所接受的优化方法。 在良好的数据库设计基础上&#xff0c;能有效地使用索引是SQL Server取得高性能的基础&#xff0c;SQL Serv…

c++ map用法_Python的 5 种高级用法,效率提升没毛病

原创&#xff1a;机器之心(ID&#xff1a;almosthuman2014)任何编程语言的高级特征通常都是通过大量的使用经验才发现的。比如你在编写一个复杂的项目&#xff0c;并在 stackoverflow 上寻找某个问题的答案。然后你突然发现了一个非常优雅的解决方案&#xff0c;它使用了你从不…

非对称加密算法RSA加密传输数据python3源代码实现

2019独角兽企业重金招聘Python工程师标准>>> import rsa# RSA 算法规定&#xff1a; # 待加密的字节数不能超过密钥的长度值除以 8 再减去 11NBIT 4096 CAN_ENCODE_LEN NBIT // 8 - 11 PER_ENCODE_LEN CAN_ENCODE_LEN - (CAN_ENCODE_LEN % 2) PER_DECODE_LEN CA…

(Microsoft) Visual Studio LightSwitch

在蓝色小铺&#xff0c;听到了前辈 阿源哥哥提到 Visual Studio LightSwitch"号称" 可以快速开发桌面、云端的应用程序。http://www.microsoft.com/visualstudio/en-us/lightswitch &#xff08;这里也提供下载&#xff09; 原厂提供的图片&#xff1a; 跟「正…

Python: 反方向迭代一个序列

使用内置的reversed()函数 >>> a [1, 2, 3, 4] >>> for x in reversed(a): ... print(x)out 4 3 2 1反向迭代仅仅当对象的大小可预先确定或者对象实现了 _reversed_()的特殊方法时才能生效。如果两者都不符合 &#xff0c;必须将对象转换成一个列表才行。 f…

jsp调用controller方法_RPC调用_服务注册与发现

RPC调用_单体架构_SOA架构系统架构的演变 1 传统的单体架构 1.1 什么是单体架构 一个归档包&#xff08;例如 war 格式或者 Jar 格式&#xff09;包含了应用所有功能的应用程序&#xff0c;我们通常称之 为单体应用。也称之为单体应用架构&#xff0c;这是一种比较传统的架构风…

MFC项目实战(1)文件管理器--准备篇

本程序主要实现如下功能&#xff1a; 程序通过左边的树形控件显示本地计算机中目录的结构&#xff0c;右边的列表控件则负责响应树形控件中选择的目录节点并把此节点中的所有项在列表框中显示出来&#xff0c;列表框支持奇偶行颜色设置&#xff0c;选中颜色设置和热点颜色设置&…

服务器tomcat配置教程

2018年上学期期末课程设计做了一个留言板&#xff0c;但是我需要把这个Jave Web弄到我的服务器上 首先我们可以安装jdk tomcat在启动时&#xff0c;会读取环境变量的信息&#xff0c;需要一个CATALINA_HOME 与JAVA_HOME的信息 CATALINA_HOME即tomcat的主目录&#xff0c; JAVA_…

使用tab键分割的文章能快速转换成表格。( )_EXCEL的163种使用技巧集锦-42~62

本文主要讲述了EXCEL的163种使用技巧其中20条技巧&#xff0c;待163种使用技巧全部讲述完成后&#xff0c;如有需要&#xff0c;各位看官可在评论中留下邮箱&#xff0c;小编会将整理的WORD版发给大家。42. 快速查找工作簿 你可以利用在工作表中的任何文字进行搜寻&#xff0c;…

负载测试工具Ripplet

负载测试工具RippletRipplet的最新版本&#xff1a;0.8bRipplet特征&#xff1a;1&#xff09;基于Apache License 2.0许可证&#xff1b;2&#xff09;软件程序性能和负载测试工具&#xff1b;3&#xff09;有四个分布式的Java组件&#xff1a;测试注入引擎、服务器/产品监视器…

解决ubuntu中vi不能正常使用方向键与退格键的问题

方案一&#xff1a; 问题&#xff1a; ubuntu中vi在编辑状态下方向键不能用&#xff0c;还有回格键不能删除等我们平时习惯的一些键都不能使用。 解决办法&#xff1a; 可以安装vim full版本&#xff0c;在full版本下键盘正常&#xff0c;安装好后同样使用vi命令。 安装vim&…

android通过代码设置铃声_第六十四回:Android中UI控件之SeekBar

各位看官们&#xff0c;大家好&#xff0c;上一回中咱们说的是Android中UI控件之ProgressBar的例子&#xff0c;这一回咱们的例子是UI控件之SeekBar。闲话休提&#xff0c;言归正转。让我们一起Talk Android吧&#xff01;看官们&#xff0c;SeekBar通常翻译为拖动条&#xff0…

转帖:组策略

1.什么是组策略 注册表是Windows系统中保存系统软件和应用软件配置的数据库&#xff0c;而随着Windows功能越来越丰富&#xff0c;注册表里的配置项目也越来越多&#xff0c;很多配置都可以自定义设置&#xff0c;但这些配置分布在注册表的各个角落&#xff0c;如果是手工配置&…

SQL中的left outer join,inner join,right outer join用法 (左右内连接)

SQL语句中的left outer join,inner join,right outer join用法left outer joinleft join , right outer joinright join, inner joinjoin.使用关系代数合并数据 1 关系代数 合并数据集合的理论基础是关系代数&#xff0c;它是由E.F.Codd于1970年提出的。 在关系代数的形式…

利旧IBM X3650m2 安装esxi5.1提供云桌面(备忘)

上面左边是我的个人微信&#xff0c;如需进一步沟通&#xff0c;请加微信。 右边是我的公众号“Openstack私有云”&#xff0c;如有兴趣&#xff0c;请关注。公司有一台旧服务器&#xff0c;原来的IBM X3650m2 服务器&#xff0c;2物理CPU&#xff0c;24G内存&#xff0c;8块3…

asp登录页面跳转到注册页面_Java 添加页面跳转按钮到PDF文档

概述当我们在查阅含有大量页面的PDF时&#xff0c;可通过在页面上添加跳转按钮来实现页面转换&#xff0c;以达到节约时间&#xff0c;提高效率的目的。本文将通过Java程序来演示如何给PDF文档添加页面跳转按钮。通常来说跳转可分为两种情况&#xff1a;一是跳转至特殊页面(首页…