51nod 1189 算术基本定理/组合数学
www.51nod.com/onlineJudge/questionCode.html#!problemId=1189
输入一个数N(1 <= N <= 1000000)。
输出解的数量Mod 10^9 + 7。
2
2 用到了算术基本定理的性质求解N!所有素因子的个数,和乘法原理计算所有组合。
#include<bits/stdc++.h>
using namespace std;
#define LL long long
LL mod=1e9+;
int num[];
bool is[];
void init()
{
is[]=is[]=;
int m=sqrt(+0.5);
for(int i=;i<=m;++i)
{
if(!is[i]){
for(int j=i*i;j<=;j+=i)
is[j]=;
}
}
}
int f(int N,int K)
{
int s=;
while(N){
s+=N/K;
N/=K;
}
return s;
}
int main()
{
int N,M,i,j,k,p=;
init();
cin>>N;
M=N;
for(i=;i<=M;++i)
{
if(!is[i])
num[p++]=f(M,i);
}
LL res=;
for(i=;i<p;++i)
{
res=res*(*num[i]+)%mod;
}
res=(res+)*%mod;
cout<<res<<endl;
return ;
} /* 公式化简为 : (X-N!)*(Y-N!)=(N!)2 假设N!=P1a1*P2a2*......*Pnan
那么ans=π(2*ai+1)| 1<=i<=n ,但是要求X<=Y,所以除以二之后向上取整就好了。 */
      
51nod 1189 算术基本定理/组合数学的更多相关文章
- Aladdin and the Flying Carpet LightOJ - 1341 (素数打表 + 算术基本定理)
		
题意: 就是求a的因数中大于b的有几对 解析: 先把素数打表 运用算术基本定理 求出a的所有因数的个数 然后减去小于b的因数的个数 代码如下: #include <iostream> #i ...
 - LightOJ - 1341  Aladdin and the Flying Carpet (算术基本定理)
		
题意: 就是....求a的所有大于b的因子有多少对 算术基本定理求 所有因子 阿欧...偷张图. 注意范围 就好 ..... 解析: 在1 -1012的范围内求大于b的所有a的因子的对数(有几对) ...
 - Pairs Forming LCM (LightOJ - 1236)【简单数论】【质因数分解】【算术基本定理】(未完成)
		
Pairs Forming LCM (LightOJ - 1236)[简单数论][质因数分解][算术基本定理](未完成) 标签: 入门讲座题解 数论 题目描述 Find the result of t ...
 - Aladdin and the Flying Carpet (LightOJ - 1341)【简单数论】【算术基本定理】【分解质因数】
		
Aladdin and the Flying Carpet (LightOJ - 1341)[简单数论][算术基本定理][分解质因数](未完成) 标签:入门讲座题解 数论 题目描述 It's said ...
 - Sigma Function (LightOJ - 1336)【简单数论】【算术基本定理】【思维】
		
Sigma Function (LightOJ - 1336)[简单数论][算术基本定理][思维] 标签: 入门讲座题解 数论 题目描述 Sigma function is an interestin ...
 - hdu4479 (数学题)(算术基本定理)
		
题目大意 给定一个三元组\((x,y,z)\)的\(gcd\)和\(lcm\),求可能的三元组的数量是多少,其中三元组是的具有顺序的 其中\(gcd\)和\(lcm\)都是32位整数范围之内 由算术基 ...
 - Pairs Forming LCM LightOJ - 1236 (算术基本定理)
		
题意: 就是求1-n中有多少对i 和 j 的最小公倍数为n (i <= j) 解析: 而这题,我们假设( a , b ) = n ,那么: n=pk11pk22⋯pkss, a=pd11pd2 ...
 - LCM Cardinality UVA - 10892(算术基本定理)
		
这题就是 LightOJ - 1236 解析去看这个把https://www.cnblogs.com/WTSRUVF/p/9185140.html 贴代码了: #include <iostrea ...
 - lightoj 1341 Aladdin and the Flying Carpet(算术基本定理)题解
		
题意:给一个矩形(非正方形)面积a和最小边长b,要求边长均大于b,求这样的矩形有几个 思路:先用到了之前学的质因数分解,还有一个新的公式: 然后我们可以先算出a的所有约数,因为只算约数个数面积重复,所 ...
 
随机推荐
- ThinkPHP在入口文件中判断是手机还是PC端访问网站
			
<?php// +----------------------------------------------------------------------// | ThinkPHP [ WE ...
 - Linux下源码安装redis,编译安装
			
1.下载redis源码 [root@localhost opt]# wget http://download.redis.io/releases/redis-4.0.10.tar.gz 2.解压缩 [ ...
 - Web安全相关资料
			
Asp.net安全架构: http://www.cnblogs.com/luminji/category/381486.html
 - 【HackerRank】Manasa and Stones
			
Change language : Manasa 和 她的朋友出去徒步旅行.她发现一条小河里边顺序排列着带有数值的石头.她开始沿河而走,发现相邻两个石头上的数值增加 a 或者 b. 这条小河的尽头有一 ...
 - Android签名机制之---签名过程详解
			
http://www.2cto.com/kf/201512/455388.html 一.前言 又是过了好长时间,没写文章的双手都有点难受了.今天是圣诞节,还是得上班.因为前几天有一个之前的同事,在申请 ...
 - 初识python---简介,简单的for,while&if
			
一编程语言:编程语言是程序员与计算机沟通的介质: 编程语言的分类: 1机器语言:是用二进制代码表示的计算机能直接识别和执行的一种机器指令的集合. 优点:灵活,直接执行和速度快 ...
 - @MarkFan 口语练习录音 20140401
			
Hi,everybody 对于未来,我只梦想最好的情况, 并定下最踏实的计划,而绝不花时间在无谓的担心上, 因为我知道,只要把我对自己的承诺付诸实践, 我的未来将不会只是一个梦…… 这是引用考拉小巫的 ...
 - HttpUtils工具类
			
HttpUtils工具类 package net.hs.itn.teng.common.util; import java.io.IOException; import java.io.Unsuppo ...
 - UITableViewCell使用时注意事项
			
1,注意使用重用机制(有利于提高效率) 2,做到通过改变模型去间接改变UI样式(做到永久改变,无论怎样拖动刷新,都不会恢复改变) 3,在通过传递模型给Cell控件布局时,记得完全覆盖(嗯,不好解释,主 ...
 - IEnumerable的一些基本方法 补充
			
接上一篇,我们发现两表连接方式默认为内连接,而我们在SQL中常用到的左连接没有封装方法.换句话说,微软放弃两表左连或右连的这种做法(只有在2个表都存在值时,这样的连接才有意义). 如果要实现表的左连接 ...