UVA10325--- The Lottery (容斥)

简介:
#include <iostream>
#include <cstdio>
using namespace std;
typedef long long  LL;
LL get[18];
LL gcd(LL m, LL n)
{
    if(n == 0)
    return m;
    return gcd(n, m%n);
}

LL lcm(LL a, LL b)
{
    LL t=gcd(a, b);
    return a/t*b;
}
int main()
{
    int n,m;
    while(cin>>m>>n)
    {
        for(int i=0; i<n; i++)
        cin>>get[i];
        int sum=0;
        for(int i=1; i<(1<<n); i++)
        {
            LL ans=1;
            int cnt=0;
            for(int j=0; j<n; j++)
            {
                if(i&(1<<j))
                {
                    ans=lcm(ans,get[j]);
                    if(ans>m)
                    break;
                    cnt++;
                }
            }
            if(ans>m)
            continue;
            if(cnt&1)
            sum+=m/ans;
            else
            sum-=m/ans;
        }
        cout<<m-sum<<endl;
    }
    return 0;
}
目录
相关文章
uva127 "Accordian" Patience
uva127 "Accordian" Patience
42 0
UVa11076 - Add Again
UVa11076 - Add Again
54 0
扩展KMP --- HDU 3613 Best Reward
Best Reward Problem's Link:   http://acm.hdu.edu.cn/showproblem.php?pid=3613   Mean:  给你一个字符串,每个字符都有一个权值(可能为负),你需要将这个字符串分成两个子串,使得这两个子串的价值之和最大。
994 0
uva11076Add again
View Code 题意:给定n和n个数,求所有的不重复的全排列的对应数字的和。 分析:对于每个数字,在每一位出现的概率相同,那么只算出一位的结果即可。对于每一位,拿出这个数字后剩下的数字的结果,乘以这个数字对应的下标i那么就是权和了。。
631 0
uva10465Homer Simpson
题意:HM先生喜欢吃汉堡,有两种汉堡,每种无限多个,吃完第一种的汉堡一个需要m时间,第二种需要n时间,HM先生饭量很大可以不停的吃,给定一个时间t,在t时间段内希望HM先生吃尽量多的汉堡,并且空余出来的时间要尽量少 分析:是一个只有两种元素的完全背包问题。
721 0
UVA3295
题意:给出一个a*b的网格,在网格上取不共线的三点构成三角形,求三角形总数。分析:就是一一道简单的组合数计算题目,设总结点数为n,则取三个节点的个数为C(n,3),然后减去横向、竖向、斜向的三点共线的个数即可,斜线三点共线等价于所枚举的矩形的长宽成倍数关系,即gcd不为1 代码如下: #incl...
658 0