[U]3.2.1 Factorials 有点点意思的水题

php中文网
发布: 2016-06-07 15:39:06
原创
1316人浏览过

以前在XTU的比赛中做过这个题,当时没过,到后面还是用了个猥琐的方法过的。 可能是不记得了当时用的高精度法没过,这次看到这题直接采用赤裸裸的高精度,结果... 在本地跑那速度.....= =|||| 于是乎,还是采用了猥琐的方法;但是为什么每次mod100000呢??

以前在xtu的比赛中做过这个题,当时没过,到后面还是用了个猥琐的方法过的。

可能是不记得了当时用的高精度法没过,这次看到这题直接采用赤裸裸的高精度,结果... 在本地跑那速度.....= =||||

于是乎,还是采用了猥琐的方法;但是为什么每次mod100000呢??而每次mod10000就WA呢?

解释:

首先我们不能采用赤裸裸的保留末位非零数的方法。

原因:进位,使得末位为0;而在一种情况下,会发生进位,两乘数含有2和5的因子,末位为0的数例如x*10==x*2*5,所以末位为零一定包含了这两个因子!而其他情况下是不会发生末位为0的进位的。通过这样便可以将所有使得进位的因素去除,去掉等量的2和5,以保持不进位,再通过保留个位的方式得出答案。

那么为啥每次要mod100000,当A,B∈[1,4220]最多有多少进位使得末位为0?(5^5=3125)

Code:

/*
ID:bysen
LANG:C++
PROG:fact4
*/
#include<stdio.h>
#define mod 100000
using namespace std;

int main()
{
 	freopen( "fact4.in","r",stdin );
 	freopen( "fact4.out","w",stdout );
 	int n;
 	scanf( "%d",&n );
 	int ans=1;
 	for( int i=1;i<=n;i++ )
 	{
 		 while( ans%10==0 )
 		 		ans/=10;
 		 ans=(ans*i)%mod;
	}	 
	
 	while( ans%10==0 )
  		   ans/=10;
 	
 	printf( "%d\n",ans%10 );
 	return 0;
}
登录后复制


最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号