csp-s2020 T2动物园

[CSP-S2020] 动物园 - 洛谷https://www.luogu.com.cn/problem/P7076 

由题意可知:动物世界里有 2^{k} 种不同的动物,编号为 0 ~ 2^{k} -1。动物园种有n种。

饲养指南中有m条要求,动物编号的第 p_{j} 位为1,则必须购买第 q_{j} 种饲料。饲料共 c 种。数据保证 a_{i} ,q_{i} 互不相同。

 故我们先计算,哪些位至少存在一次。可用 | 运算(或运算)进行统计。

flag |= x;//根据动物编号,确定每位二进制位是否为1 

对于每个要求,如果 p_{i} 位存在,那该种饲料肯定就有了,反之则该饲料一定没有,即这一位不能位1。

除去不能为1的位,剩下的 t 个位可能位 1 ,则总动物数为 2^{t} ,减去动物园种已有的 n 种动物,即为答案。

注意 n=0,t=64 的情况。

代码如下:

#include <bits/stdc++.h>
#define ULL unsigned long long
using namespace std;
int main(){
	int n, m, c, K;
    scanf("%d%d%d%d", &n, &m, &c, &K);
    ULL flag = 0, g = 0;
    for (int i = 0; i < n; i++) {
        ULL x;
        scanf("%llu", &x);
        flag |= x;//根据动物编号,确定每位二进制位是否为1 
    }
    while (m--) {
        int p,q;
        scanf("%d%d", &p,&q);
        if((flag >> p & 1) == 0)//如果第p位二进制位为0,即该种饲料一定没有。 
			g |= 1ULL << p;//标记一下哪一位一定不会有。 
    }
    ULL ans = 1;
    for (int i = 0; i < K; i++) {
        if ((g >> i & 1) == 0) ans <<= 1;//除去一定不能为 1的位,剩下t个位可能为 1
    }
    if (ans == 0 && n == 0) {
        puts("18446744073709551616");
        return 0;
    }
    ans -= n;
    printf("%llu\n", ans);
    return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值