POJ 1091 跳蚤

 

 Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 9914   Accepted: 3032

Description

Z 城市居住着很多只跳蚤。在Z城市周六生活频道有一个娱乐节目。一只跳蚤将被请上一个高空钢丝的正中央。钢丝很长,可以看作是无限长。节目主持人会给该跳蚤 发一张卡片。卡片上写有N+1个自然数。其中最后一个是M,而前N个数都不超过M,卡片上允许有相同的数字。跳蚤每次可以从卡片上任意选择一个自然数S, 然后向左,或向右跳S个单位长度。而他最终的任务是跳到距离他左边一个单位长度的地方,并捡起位于那里的礼物。
比如当N=2,M=18时,持有卡片(10, 15,
18)的跳蚤,就可以完成任务:他可以先向左跳10个单位长度,然后再连向左跳3次,每次15个单位长度,最后再向右连跳3次,每次18个单位长度。而持
有卡片(12, 15, 18)的跳蚤,则怎么也不可能跳到距他左边一个单位长度的地方。

当确定N和M后,显然一共有M^N张不同的卡片。现在的问题是,在这所有的卡片中,有多少张可以完成任务。

Input

两个整数N和M(N <= 15 , M <= 100000000)。

Output

可以完成任务的卡片数。

Sample Input

2 4

Sample Output

12

用到素因子分解,高精度,以及集合中的互斥原理。代码如下:

 1 #include <stdio.h>
 2
 3 long long factor[10000000];
 4 long long  factor_num = 0;
 5
 6 long long M;
 7 long long N;
 8
 9
10 void get_factor(long long num, long long factor[], long long *factor_num)
11 {
12     *factor_num = 0;
13     for (long long i = 2; i * i <= num ; i++)
14     {
15         if (num %i == 0)
16         {
17             *factor_num = (*factor_num) + 1;
18             factor[*factor_num] = i;
19             while( num % i == 0)
20             {
21                 num = num / i;
22             }
23         }
24     }
25     if(num > 1)
26     {
27         *factor_num = (*factor_num) + 1;
28         factor[*factor_num] = num;
29     }
30 }
31
32
33 long long pow(long long x, long long index)
34 {
35     long long result = 1;
36     for (long long i = 1; i <= index; i++)
37     {
38         result *= x;
39     }
40     return result;
41 }
42
43
44
45 int main(int argc, char * argv[])
46 {
47
48     scanf("%lld", &N);
49     scanf("%lld", &M);
50
51     //printf("N=%d M=%ld\n", N, M);
52
53     long long total = pow(M, N);
54     get_factor(M,  factor, &factor_num);
55
56     //printf("total=%ld\n", total);
57
58
59     unsigned long long bi_factor_num = (1 << factor_num);
60     //printf("bi_factor_num=%d\n", bi_factor_num);
61
62
63     for (unsigned long long i = 1; i < bi_factor_num; i++)
64     {
65         //printf("%d-----\n", i);
66         long long t = 0;
67         long long facts = 1;
68         long long  k = 1;
69         for (unsigned long long j = i;  j >=  1; j = j >> 1)
70         {
71             if (j & 1)
72             {
73                 t++;
74                 facts *= factor[k];
75             }
76             k++;
77             //printf("j =%d\n", j);
78             //printf("k =%d\n", k);
79         }
80             //printf("facts = %d  %d %d\n", facts, t, pow(M/facts, N));
81             if (t % 2 == 1)
82             {
83                 total = total - pow(M/facts, N);
84             }
85             else if (t % 2 == 0)
86             {
87                 total = total + pow(M/facts, N);
88             }
89
90     }
91
92     //printf("Done\n");
93     printf("%lld\n", total);
94     return 0;
95 }
时间: 2024-08-28 10:26:19

POJ 1091 跳蚤的相关文章

POJ 1091 跳蚤(分解质因数 + 容斥 + 大数)

跳蚤 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 8910   Accepted: 2676 Description Z城市居住着很多只跳蚤.在Z城市周六生活频道有一个娱乐节目.一只跳蚤将被请上一个高空钢丝的正中央.钢丝很长,可以看作是无限长.节目主持人会给该跳蚤发一张卡片.卡片上写有N+1个自然数.其中最后一个是M,而前N个数都不超过M,卡片上允许有相同的数字.跳蚤每次可以从卡片上任意选择一个自然数S,然后向左,或向

poj 1091 跳骚

1 /** 2 题意: 求对于小于m的n个数, 求x1*a1 + x2*a2+x3*a3........+xn*an = 1 3 即求 a1,a2,a3,....an 的最大公约数为1 , a1,a2....an 可重复 4 原理 : 容斥原理 所有的 排序即 m^n --不符合的情况 ,即为所求 5 不符合的情况: 就是 这n个数有最大公约数 不是1, 即这n个数是m 的素因子的组合.. 6 一共有 m^n张卡片,如果减去其中含有公约数的卡片剩下的就是所求的结果 7 举个例子 n=2, m=3

POJ 1091 容斥原理

链接: http://poj.org/problem?id=1091 题意: 给你两个正整数n,m,让你求长度为n+1的满足条件的一个等式:a[1]*x1+a[2]*x2+a[3]*x3+...+a[n]*xn+a[n+1]*x(n+1)=1 (0<=a[i]<=m&&a[n+1]=m) 让你求一共有多少种情况满足这个条件. 要使得 a[1]*x1+a[2]*x2+a[3]*x3+...+a[n]*xn+a[n+1]*m=1 (0<=a[i]<=m),那么a[1],

poj 1091 解多元不定方程

跳蚤 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 9225   Accepted: 2762 Description Z城市居住着很多只跳蚤.在Z城市周六生活频道有一个娱乐节目.一只跳蚤将被请上一个高空钢丝的正中央.钢丝很长,可以看作是无限长.节目主持人会给该跳蚤发一张卡片.卡片上写有N+1个自然数.其中最后一个是M,而前N个数都不超过M,卡片上允许有相同的数字.跳蚤每次可以从卡片上任意选择一个自然数S,然后向左,或向

POJ 1091

这题确实是好. 其实是求x1*a1+x2*a2+....M*xn+1=1有解的条件.很明显,就是(a1,a2,...M)=1了.然后,可以想象,直接求有多少种,很难,所以,求出选择哪些数一起会不与M互质...好吧,思路就到这里了...T_T 经过人提示,若(a1,a2,,,,an)与M不互质,则最大公约数中必定包含M中的质数.啊,愰然大悟,这不是显而易见的吗?为什么我想不到? 所以,先求出M包含哪些质数,那么,选出其中一些包含该质数的数组成数列不就好了?这很容易就能想到容斥原理了,因为选出一些数

ACM 容斥原理

VJ 点击打开链接 参考 点击打开链接 非常好的译文:点击打开链接 容斥原理的想法就是求多个集合的并集.所以要先设计好集合. 组合数学问题中,正面解决会困难,常用方法是正难则反,使用容斥原理求反向在用全集减去.将对立面的限制条件分析清楚. eg 求区间互质的数的个数,则用除法等计算出一个数的倍数的方法再减去. UVa 11806 Cheerleaders 求k个石子放在n*m的矩阵里 并且第一行 最后一行 第一列 最后一列都要有石子 考虑反面 求出所有的 减去不满足的情况 容斥原理总共4个 集合

POJ 跳蚤

Z城市居住着很多只跳蚤.在Z城市周六生活频道有一个娱乐节目.一只跳蚤将被请上一个高空钢丝的正中央.钢丝很长,可以看作是无限长.节目主持人会给该跳蚤发一张卡片.卡片上写有N+1个自然数.其中最后一个是M,而前N个数都不超过M,卡片上允许有相同的数字.跳蚤每次可以从卡片上任意选择一个自然数S,然后向左,或向右跳S个单位长度.而他最终的任务是跳到距离他左边一个单位长度的地方,并捡起位于那里的礼物. 比如当N=2,M=18时,持有卡片(10, 15, 18)的跳蚤,就可以完成任务:他可以先向左跳10个单

POJ 3449 Geometric Shapes --计算几何,线段相交

题意: 给一些多边形或线段,输出与每一个多边形或线段的有哪一些多边形或线段. 解法: 想法不难,直接暴力将所有的图形处理成线段,然后暴力枚举,相交就加入其vector就行了.主要是代码有点麻烦,一步一步来吧. 还有收集了一个线段旋转的函数. Vector Rotate(Point P,Vector A,double rad){ //以P为基准点把向量A旋转rad return Vector(P.x+A.x*cos(rad)-A.y*sin(rad),P.y+A.x*sin(rad)+A.y*co

POJ题目推荐(转载)

POJ推荐50题1.标记“难”和“稍难”的题目可以看看,思考一下,不做要求,当然有能力的同学可以直接切掉.2.标记为A and B的题目是比较相似的题目,建议大家两个一起做,可以对比总结,且二者算作一个题目.3.列表中大约有70个题目.大家选做其中的50道,且每类题目有最低数量限制.4.这里不少题目在BUPT ACM FTP上面都有代码,请大家合理利用资源.5.50个题目要求每个题目都要写总结,养成良好的习惯.6.这个列表的目的在于让大家对各个方面的算法有个了解,也许要求有些苛刻,教条,请大家谅