hi.鱼与熊掌

L2-049 鱼与熊掌

题目描述

在这里插入图片描述

《孟子 · 告子上》有名言:“鱼,我所欲也,熊掌,亦我所欲也;二者不可得兼,舍鱼而取熊掌者也。”但这世界上还是有一些人可以做到鱼与熊掌兼得的。

给定 n n n 个人对 m m m 种物品的拥有关系。对其中任意一对物品种类(例如“鱼与熊掌”),请你统计有多少人能够兼得?

输入格式:

输入首先在第一行给出 2 2 2 个正整数,分别是: n ( ≤ 1 0 5 ) n(≤10 ^5 ) n105为总人数(所有人从 1 1 1 n n n 编号)、 m ( 2 ≤ m ≤ 1 0 5 ) m(2≤m≤10^ 5 ) m2m105为物品种类的总数(所有物品种类从 1 1 1 m m m 编号)。

随后 n n n 行,第 i i i ( 1 ≤ i ≤ n ) (1≤i≤n) 1in给出编号为 i i i 的人所拥有的物品种类清单,格式为:

K M[1] M[2] ... M[K]

其中 K ( ≤ 1 0 3 ) K(≤10 ^3 ) K103是该人拥有的物品种类数量,后面的 M [ ∗ ] M[*] M[] 是物品种类的编号。题目保证每个人的物品种类清单中都没有重复给出的种类。

最后是查询信息:首先在一行中给出查询总量 Q ( ≤ 100 ) Q(≤100) Q100,随后 Q Q Q 行,每行给出一对物品种类编号,其间以空格分隔。题目保证物品种类编号都是合法存在的。

输出格式:

对每一次查询,在一行中输出两种物品兼得的人数。

输入样例:

4 8
3 4 1 8
4 7 1 8 4
5 6 5 1 2 3
4 3 2 4 8
3
2 3
7 6
8 4

输出样例:

2
0
3

代码内容

#include <bits/stdc++.h>
using namespace std;

typedef long long ll;
const ll N=1e3+10;
ll tt[N];
ll pos[N][N];

int main()
{
    ll n,m;
    cin>>n>>m;
    for(ll i=1;i<=n;i++)
    {
        ll k;
        cin>>k;
        tt[i]=k;
        for(ll j=1;j<=k;j++)
            cin>>pos[i][j];
    }

    ll q;
    cin>>q;
    ll x,y;

    while(q--)
    {
        ll index=0;
        cin>>x>>y;
        
        for(ll i=1;i<=n;i++)
        {
            ll a=0,b=0;
            for(ll j=1;j<=tt[i];j++)
            {
                if(x==pos[i][j]) a=1;
                if(y==pos[i][j]) b=1;
            }

            if(a&&b) index++;
        }

        cout<<index<<endl;
    }

    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Pretty Boy Fox

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值