博客
关于我
UVA10325 The Lottery(容斥)
阅读量:224 次
发布时间:2019-03-01

本文共 1820 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要计算区间[1, n]中不被给定数组中的任何一个数整除的数的个数。我们可以通过反向思维,计算被至少一个数整除的数的个数,然后用总数减去这个数目来得到结果。

方法思路

  • 问题分析:我们需要找出在区间[1, n]中不被数组a中的任何一个数整除的数的个数。我们可以用容斥原理来计算至少被一个数整除的数的个数,然后用总数减去这个数目。
  • 容斥原理:我们可以通过枚举所有可能的子集来计算至少被一个数整除的数的个数。对于每个子集,计算其最小公倍数(LCM),然后根据子集的大小来决定加或减这个数目。
  • 优化方法:由于m最多为15,枚举所有子集(2^15=32768)是可行的。我们可以用二进制枚举来表示每个子集,并计算其对应的LCM。
  • LCM计算:对于每个子集,计算其对应的LCM_val。如果LCM_val大于n,则这个子集对结果没有贡献,跳过计算。
  • 解决代码

    #include 
    using namespace std;int main() { ios::sync_with_stdio(0); long long n, m; vector
    a; for (int i = 0; i < m; ++i) { int num; cin >> num; a.push_back(num); } // 去重 sort(a.begin(), a.end()); auto it = unique(a.begin(), a.end()); a.erase(it, a.end()); m = it - a.begin(); long long ans = n; for (int mask = 1; mask < (1 << m); ++mask) { int k = __builtin_popcount(mask); long long lcm_val = 1; bool overflow = false; for (int j = 0; j < m; ++j) { if (mask & (1 << j)) { int num = a[j]; if (lcm_val == 0) { lcm_val = num; } else { long long g = __gcd(lcm_val, num); lcm_val = (lcm_val / g) * num; if (lcm_val > n) { overflow = true; break; } } } } if (overflow) continue; long long count = n / lcm_val; if (k % 2 == 1) { ans += count; } else { ans -= count; } } cout << ans << endl; return 0;}

    代码解释

  • 读取输入:读取n和m,以及数组a。
  • 去重处理:将数组a去重,避免重复计算。
  • 枚举子集:从1到2^m -1枚举所有可能的子集。
  • 计算k和LCM_val:对于每个子集,计算其大小k和对应的LCM_val。如果LCM_val超过n,跳过计算。
  • 计算贡献数目:根据子集的大小k,决定是加还是减当前子集的贡献数目。
  • 输出结果:最终输出不能被任何数组元素整除的数目。
  • 这种方法通过枚举所有子集并利用容斥原理,高效地解决了问题,确保了计算的准确性和效率。

    转载地址:http://pukv.baihongyu.com/

    你可能感兴趣的文章
    OSPF技术连载18:OSPF网络类型:非广播、广播、点对多点、点对多点非广播、点对点
    查看>>
    OSPF技术连载19:深入解析OSPF特殊区域
    查看>>
    SQL Server 复制 订阅与发布
    查看>>
    OSPF技术连载20:OSPF 十大LSA类型,太详细了!
    查看>>
    OSPF技术连载21:OSPF虚链路,现代网络逻辑连接的利器!
    查看>>
    OSPF技术连载22:OSPF 路径选择 O > O IA > N1 > E1 > N2 > E2
    查看>>
    OSPF技术连载2:OSPF工作原理、建立邻接关系、路由计算
    查看>>
    OSPF技术连载5:OSPF 基本配置,含思科、华为、Junifer三厂商配置
    查看>>
    OSPF技术连载6:OSPF 多区域,近7000字,非常详细!
    查看>>
    OSPF技术连载7:什么是OSPF带宽?OSPF带宽参考值多少?
    查看>>
    OSPF技术连载8:OSPF认证:明文认证、MD5认证和SHA-HMAC验证
    查看>>
    OSPF故障排除技巧
    查看>>
    spring配置文件中<context:property-placeholder />的使用
    查看>>
    OSPF有哪些优势?解决了RIP的什么问题?
    查看>>
    OSPF的七种类型LSA
    查看>>
    OSPF的安全性考虑:全面解析与最佳实践
    查看>>
    ospf综合实验2 2012/9/8
    查看>>
    OSPRay 开源项目教程
    查看>>
    OSS 访问图片资源报“No ‘Access-Control-Allow-Origin‘”的错误
    查看>>
    oss报UnknownHost,k8s设置hostAliases参数
    查看>>