专栏文章

AT_abc402_c 题解

题解参与者 1已保存评论 0

文章操作

快速查看文章及其快照的属性,并进行相关操作。

当前评论
0 条
当前快照
1 份
快照标识符
@mipk0g5h
此快照首次捕获于
2025/12/03 13:15
3 个月前
此快照最后确认于
2025/12/03 13:15
3 个月前
查看原文

思路

首先可以注意到,每道菜能吃的时间,只跟其中在数组 BB 中出现过的配菜能吃的时间相关,也就是这道菜之中最晚能吃那个配菜的时间。
知道题几乎已经解决了。首先将 BB 中的配菜开个桶记下来,跑每个菜的每道配菜从而可以知道这道菜能吃的时间。
注意到每道菜能吃的时间是具有单调性的。也就是如果这道菜 tt 秒能吃,那么 t+1t+1 秒也能吃。所以将每道菜的最早可吃时间排序一下,每走到一个新的时间点加上其对应的菜的数目就做完啦!

AC code

CPP
#include<bits/stdc++.h>
using namespace std;
long long n,m,k[300005],bt[300005],cm[300005];
vector<long long>a[300005];
int main(){
    scanf("%lld%lld",&n,&m);
    for(int i=1;i<=m;i++){
        scanf("%lld",&k[i]);
        for(int j=1;j<=k[i];j++){
            long long _;
            scanf("%lld",&_);
            a[i].push_back(_);
        }
    }
    for(int i=1;i<=n;i++){
        long long _;
        scanf("%lld",&_);
        bt[_]=i;
    }
    for(int i=1;i<=m;i++){
        for(int j=0;j<k[i];j++){
            cm[i]=max(cm[i],bt[a[i][j]]);
        }
    }
    sort(cm+1,cm+m+1);
    long long j=1;
    for(int i=1;i<=n;i++){
        while(cm[j]<=i && j<=m)j++;
        printf("%lld\n",j-1);
    }
}

评论

0 条评论,欢迎与作者交流。

正在加载评论...