题意:

输入n,求c(n,0)到c(n,n)的所有组合数的最小公倍数。

输入:

首行输入整数t,表示共有t组测试样例。

每组测试样例包含一个正整数n(1<=n<=1e6)。

输出:

输出结果(mod 1e9+7)。

感觉蛮变态的,从比赛开始我就是写的这道题,比赛结束还是没写出来……

期间找到了逆元,最小公倍数,组合数的各种公式,但是爆了一下午tle。

比赛结束,题解告诉我,公式秒杀法……

但是公式看不懂,幸好有群巨解说,所以有些听懂了,但还是需要继续思考才能弄懂。

题解:

设ans[i]表示i的所有组合数的最小公倍数。

设f[i]表示从1到i的正整数的最小公倍数。

然后获得从f[i]到ans[i]的公式——ans[i] = f[i+1]/i。                anss[i-1] = (f[i]*inv[i])%Mod;

然后获得求f[i]的公式——

  if(i == p^k) f[i] = f[i-1]*p;

  else f[i] = f[i-1];

接下来需要做的就是找到那些i == p^k了。

解题步骤:

1. 打素数表;

2. 由素数表寻找i == p^k;

3. f[1] = 1,打f[]数组表和ans[]数组表;

4. 输入数据;

5. 根据输入数据和ans[]表输出答案。

我认为还有其他方法,因为ac的程序的运行时间从15ms到900+ms都有。更多方法持续寻找中。

我的(根据题解的)代码——

 #include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std; #define LL long long
const int N = ;
const int Mod = ; int n, t;
LL ans, mid;
LL inv[N];
LL anss[N];
bool su2[N];
int su[N], su1[N];
LL f[N]; //f[i]表示1~i的最小公倍数 void table()
{
inv[] = ;
for(int i = ; i < N; i++) //求i的逆元
{
inv[i] = inv[Mod%i]*(Mod-Mod/i) % Mod;
} memset(su2, , sizeof(su2));
memset(su1, , sizeof(su1));
su2[] = su2[] = ; //求N以内的素数
su2[] = ;
for(int i = ; i < N; i++) su2[i] = i% == ? : ;
for(int i = ; i <= sqrt(N*1.0); i++)
{
if(su2[i])
{
for(int j = i*i; j <= N; j += *i)
{
su2[j] = ;
}
}
}
int k = ;
for(int i = ; i < N; i++) //打N以内的素数表
{
if(su2[i] == ) su[k++] = i;
}
for(int i = ; i < k; i++) //寻找满足p^k的数,其中p为素数,k为正整数
{
LL mid = su[i];
while(mid < N)
{
su1[mid] = su[i];
mid *= su[i];
}
}
f[] = ; //打N以内的1~i的最小公倍数表
for(int i = ; i < N; i++)
{
if(su1[i]) f[i] = f[i-]*su1[i];
else f[i] = f[i-];
f[i] %= Mod;
anss[i-] = (f[i]*inv[i])%Mod; //答案表
}
} int main()
{
//freopen("test.in", "r", stdin);
//freopen("test.out", "r", stdout);
table();
scanf("%d", &t);
while(t--)
{
scanf("%d", &n);
printf("%I64d\n", anss[n]);
}
return ;
}

hdu 5407 CRB and Candies(组合数+最小公倍数+素数表+逆元)2015 Multi-University Training Contest 10的更多相关文章

  1. HDU 5407 CRB and Candies(LCM +最大素因子求逆元)

    [题目链接]pid=5407">click here~~ [题目大意]求LCM(Cn0,Cn1,Cn2....Cnn)%MOD 的值 [思路]来图更直观: 这个究竟是怎样推出的.说实话 ...

  2. Hdu 5407 CRB and Candies (找规律)

    题目链接: Hdu 5407 CRB and Candies 题目描述: 给出一个数n,求lcm(C(n,0),C[n,1],C[n-2]......C[n][n-2],C[n][n-1],C[n][ ...

  3. HDU 5407——CRB and Candies——————【逆元+是素数次方的数+公式】

    CRB and Candies Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  4. HDU 5407(2015多校10)-CRB and Candies(组合数最小公倍数+乘法逆元)

    题目地址:pid=5407">HDU 5407 题意:CRB有n颗不同的糖果,如今他要吃掉k颗(0<=k<=n),问k取0~n的方案数的最小公倍数是多少. 思路:首先做这道 ...

  5. 2015 Multi-University Training Contest 10 hdu 5407 CRB and Candies

    CRB and Candies Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  6. LCM性质 + 组合数 - HDU 5407 CRB and Candies

    CRB and Candies Problem's Link Mean: 给定一个数n,求LCM(C(n,0),C(n,1),C(n,2)...C(n,n))的值,(n<=1e6). analy ...

  7. HDU 5407 CRB and Candies

    题意:给一个正整数k,求lcm((k, 0), (k, 1), ..., (k, k)) 解法:在oeis上查了这个序列,得知答案即为lcm(1, 2, ..., k + 1) / (k + 1),而 ...

  8. hdu 5416 CRB and Tree(2015 Multi-University Training Contest 10)

    CRB and Tree                                                             Time Limit: 8000/4000 MS (J ...

  9. 2015 Multi-University Training Contest 10 hdu 5406 CRB and Apple

    CRB and Apple Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

随机推荐

  1. Appboy 基于 MongoDB 的数据密集型实践

    摘要:Appboy 正在过手机等新兴渠道尝试一种新的方法,让机构可以与顾客建立更好的关系,可以说是市场自动化产业的一个前沿探索者.在移动端探索上,该公司已经取得了一定的成功,知名产品有 iHeartM ...

  2. POJ1144 Network 无向图的割顶

    现在打算重新学习图论的一些基础算法,包括像桥,割顶,双连通分量,强连通分量这些基础算法我都打算重敲一次,因为这些量都是可以用tarjan的算法求得的,这次的割顶算是对tarjan的那一类算法的理解的再 ...

  3. poj 3620 Avoid The Lakes(广搜,简单)

    题目 找最大的一片湖的面积,4便有1边相连算相连,4角不算. runtime error 有一种可能是 数组开的太小,越界了 #define _CRT_SECURE_NO_WARNINGS #incl ...

  4. SQL事物用法【转】

    SQL事务 一.事务概念 事务是一种机制.是一种操作序列,它包含了一组数据库操作命令,这组命令要么全部执行,要么全部不执行.因此事务是一个不可分割的工作逻辑单元.在数据库系统上执行并发操作时事务是作为 ...

  5. *[hackerrank]Volleyball Match

    https://www.hackerrank.com/contests/w1/challenges/volleyball-match 此题不错,首先可以看出是DP,S(x, y)= S(x - 1, ...

  6. 方法Equals和操作符==的区别

    http://www.codeproject.com/Articles/584128/What-is-the-difference-between-equalsequals-and-Eq When w ...

  7. OEM status|start|stop

    OEM一旦建立以后,LINUX的主机名(hosts)就不要去改变. [oracle@redhat4 ~]$ emctl start dbconsoleOC4J Configuration issue. ...

  8. poj 2891 Strange Way to Express Integers (扩展gcd)

    题目链接 题意:给k对数,每对ai, ri.求一个最小的m值,令m%ai = ri; 分析:由于ai并不是两两互质的, 所以不能用中国剩余定理. 只能两个两个的求. a1*x+r1=m=a2*y+r2 ...

  9. poj 3273 Monthly Expense(贪心+二分)

    题目:http://poj.org/problem?id=3273 题意:把n个数分成m份,使每份的和尽量小,输出最大的那一个的和. 思路:二分枚举最大的和,时间复杂度为O(nlog(sum-max) ...

  10. 设置图片Alpha

    Drawable ico = getResources().getDrawable(R.drawable.search_box);                       mSearchLayou ...