QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#605027#8759. 小班课UESTC_DECAYALI#WA 35ms11656kbC++203.2kb2024-10-02 15:06:062024-10-02 15:06:09

Judging History

你现在查看的是最新测评结果

  • [2024-10-02 15:06:09]
  • 评测
  • 测评结果:WA
  • 用时:35ms
  • 内存:11656kb
  • [2024-10-02 15:06:06]
  • 提交

answer

#include<cstdio>
#include<iostream>
#include<vector>
#include<cstring>
#include<queue>
#include<algorithm>
#define RI register int
#define CI const int&
using namespace std;
const int N=505,INF=1e9;
int T,n,m,b[N],valid[N],mat[N],rb[N]; vector <int> a[N];
namespace Network_Flow
{
    const int NN=1005,MM=5e6+5;
    struct edge
    {
        int to,nxt,v;
    }e[MM<<1]; int cnt=1,head[NN],cur[NN],dep[NN],s,t;
    inline void addedge(CI x,CI y,CI z)
    {
        e[++cnt]=(edge){y,head[x],z}; head[x]=cnt;
        e[++cnt]=(edge){x,head[y],0}; head[y]=cnt;
    }
    #define to e[i].to
    inline bool BFS(void)
    {
        memset(dep,0,(t+1)*sizeof(int)); dep[s]=1;
        queue <int> q; q.push(s);
        while (!q.empty())
        {
            int now=q.front(); q.pop();
            for (RI i=head[now];i;i=e[i].nxt)
            if (e[i].v&&!dep[to]) dep[to]=dep[now]+1,q.push(to);
        }
        return dep[t];
    }
    inline int DFS(CI now,CI tar,int dis)
    {
        if (now==tar) return dis; int ret=0;
        for (RI& i=cur[now];i&&dis;i=e[i].nxt)
        if (e[i].v&&dep[to]==dep[now]+1)
        {
            int dist=DFS(to,tar,min(dis,e[i].v));
            if (!dist) dep[to]=INF;
            dis-=dist; ret+=dist; e[i].v-=dist; e[i^1].v+=dist;
            if (!dis) return ret;
        }
        if (!ret) dep[now]=INF; return ret;
    }
    #undef to
    inline int Dinic(int ret=0)
    {
        while (BFS()) memcpy(cur,head,(t+1)*sizeof(int)),ret+=DFS(s,t,INF); return ret;
    }
    inline void build(void)
    {
        cnt=1; for (RI i=0;i<=t;++i) head[i]=0;
        for (RI i=1;i<=n;++i) if (valid[i]) addedge(s,i,1);
        for (RI i=1;i<=m;++i) if (b[i]>0) addedge(n+i,t,b[i]);
        for (RI i=1;i<=n;++i)
        for (RI j=(int)a[i].size()-1;j>=0;--j) addedge(i,n+a[i][j],1);
    }
};
using namespace Network_Flow;
int main()
{
    //freopen("1.in","r",stdin);
    for (scanf("%d",&T);T;--T)
    {
        scanf("%d%d",&n,&m); s=n+m+1; t=s+1;
        for (RI i=1;i<=n;++i) valid[i]=1;
        for (RI i=1;i<=m;++i) scanf("%d",&b[i]),rb[i]=0;
        for (RI i=1;i<=n;++i)
        {
            int x; scanf("%d",&x); a[i].resize(x);
            for (RI j=0;j<a[i].size();++j) scanf("%d",&a[i][j]);
        }
        build(); int flow=Dinic();
        printf("%d\n",flow);
        for (RI i=1;i<=n;++i)
        {
            mat[i]=-1;
            for (RI j=head[i];j;j=e[j].nxt)
            if (1<=e[j].to-n&&e[j].to-n<=m&&e[j].v==0)
            {
                mat[i]=e[j].to-n; ++rb[mat[i]]; break;
            }
        }
        vector <int> ans;
        for (RI k=1;k<=n;++k)
        {
            for (RI i=1;i<=n;++i)
            {
                if (!valid[i]) continue;
                bool flag=1;
                for (auto x:a[i])
                {
                    if (x==mat[i]) break;
                    if (rb[x]>0) { flag=0; break; }
                }
                if (flag)
                {
                    ans.push_back(i); valid[i]=0;
                    if (mat[i]!=-1) --rb[mat[i]];
                    break;
                }
            }
        }
        for (auto x:ans) printf("%d ",x); putchar('\n');
    }
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 4096kb

input:

3
5 5
1 1 1 1 1
4 1 3 2 4
1 5
4 3 4 2 1
2 3 5
1 1
5 3
1 2 2
2 1 2
2 1 2
2 1 3
2 1 3
2 1 3
5 5
1 1 1 1 1
2 1 2
2 5 4
2 3 2
2 4 3
2 5 1

output:

5
2 4 3 5 1 
5
5 1 2 3 4 
5
2 3 4 5 1 

result:

ok Correct!

Test #2:

score: 0
Accepted
time: 1ms
memory: 3840kb

input:

250
2 1
2
1 1
1 1
1 1
1
0
2 2
1 1
1 1
2 2 1
2 2
0 2
2 1 2
1 2
1 1
1
1 1
1 2
1 0
0
1 2
1 0
0
2 1
2
1 1
0
1 2
1 0
0
2 1
2
1 1
1 1
1 1
1
1 1
1 2
1 0
1 2
2 2
2 0
1 1
1 2
1 1
1
0
1 1
1
0
1 2
0 1
1 1
2 2
1 1
1 1
2 1 2
2 2
1 1
2 2 1
2 2 1
1 2
0 1
1 2
2 1
2
1 1
0
2 2
2 0
1 1
1 2
1 1
1
1 1
2 1
2
0
1 1
1 1
1
...

output:

2
1 2 
0
1 
2
1 2 
2
1 2 
1
1 
0
1 
0
1 
1
1 2 
0
1 
2
1 2 
1
1 
0
1 
1
1 2 
0
1 
0
1 
0
1 
2
1 2 
2
2 1 
1
1 
1
1 2 
1
1 2 
1
1 
1
1 2 
1
1 
1
1 2 
0
1 2 
1
1 
1
1 
0
1 
1
1 
2
1 2 
0
1 
0
1 
1
1 2 
2
1 2 
0
1 
0
1 
0
1 
0
1 2 
2
1 2 
1
1 
1
1 
0
1 
0
1 
0
1 
1
1 
1
1 
0
1 
2
1 2 
2
1 2 
1
1 2 
1
1...

result:

ok Correct!

Test #3:

score: 0
Accepted
time: 1ms
memory: 3840kb

input:

166
3 3
1 1 1
0
2 2 3
0
3 3
0 3 0
0
2 1 3
0
3 3
0 0 3
0
2 2 3
0
3 3
2 0 1
2 2 3
0
2 3 2
3 3
0 2 1
2 3 1
0
2 2 1
3 3
1 1 1
2 3 1
2 1 2
1 3
3 3
2 1 0
1 3
0
0
3 3
1 1 1
1 2
0
2 2 3
3 3
1 1 1
0
1 2
2 2 1
3 3
0 0 3
1 1
2 1 3
1 3
3 3
0 1 2
2 2 3
2 2 3
0
3 3
2 0 1
0
1 1
0
3 3
1 2 0
2 2 1
1 1
0
3 3
1 0 2
0
...

output:

1
1 2 3 
0
1 2 3 
1
1 2 3 
1
2 3 1 
2
1 2 3 
3
3 1 2 
0
1 2 3 
2
1 2 3 
2
1 2 3 
2
1 2 3 
2
2 1 3 
1
1 2 3 
2
1 2 3 
1
1 2 3 
1
1 2 3 
2
2 3 1 
2
1 2 3 
0
1 2 3 
2
1 2 3 
0
1 2 3 
1
1 2 3 
2
1 2 3 
1
1 3 2 
3
1 2 3 
3
1 2 3 
0
1 2 3 
1
1 2 3 
2
1 2 3 
2
1 2 3 
2
2 3 1 
2
1 2 3 
1
1 2 3 
2
1 2 3 
1
1...

result:

ok Correct!

Test #4:

score: 0
Accepted
time: 1ms
memory: 3840kb

input:

125
4 4
3 1 0 0
1 2
0
2 1 3
3 2 3 1
4 4
2 0 1 1
2 1 3
2 1 2
2 4 1
0
4 4
2 0 1 1
2 2 3
3 3 2 4
1 2
0
4 4
0 1 1 2
2 3 1
1 4
3 1 2 4
0
4 4
1 1 1 1
2 3 2
2 4 2
0
2 4 2
4 4
2 2 0 0
3 2 1 4
2 3 4
1 2
1 3
4 4
2 0 0 2
1 2
3 3 2 1
2 3 2
2 2 1
4 4
1 2 0 1
1 4
0
0
0
4 4
3 0 0 1
3 2 1 3
0
2 1 4
2 4 3
4 4
1 2 1 ...

output:

3
1 2 3 4 
3
1 2 3 4 
2
1 2 3 4 
3
1 2 3 4 
3
1 3 4 2 
2
1 2 3 4 
2
1 2 3 4 
1
1 2 3 4 
3
1 2 3 4 
3
2 4 1 3 
0
1 2 3 4 
2
1 2 3 4 
2
1 2 3 4 
2
1 2 3 4 
4
2 3 4 1 
2
1 2 3 4 
2
1 4 3 2 
2
3 2 4 1 
3
1 2 3 4 
4
1 2 3 4 
3
1 2 3 4 
1
1 2 3 4 
2
1 2 3 4 
3
1 2 3 4 
2
1 3 2 4 
4
1 2 3 4 
2
1 2 3 4 
3
1...

result:

ok Correct!

Test #5:

score: 0
Accepted
time: 1ms
memory: 3836kb

input:

100
5 5
2 1 2 0 0
0
2 3 2
3 5 4 3
2 1 2
0
5 5
0 2 0 0 3
1 5
0
1 1
0
0
5 5
0 1 3 0 1
2 5 4
2 1 5
0
0
3 3 1 4
5 5
1 1 0 2 1
1 2
0
2 4 5
0
1 4
5 5
0 1 1 2 1
2 4 2
0
2 1 3
0
1 1
5 5
0 0 2 2 1
2 4 3
1 4
0
3 5 4 1
3 5 1 2
5 5
1 2 1 0 1
2 1 2
0
3 3 5 2
2 4 3
0
5 5
1 0 1 1 2
0
1 4
1 3
1 3
0
5 5
1 2 1 1 0
1 ...

output:

3
1 2 3 4 5 
1
1 2 3 4 5 
2
2 1 3 4 5 
3
1 2 3 4 5 
2
1 2 3 4 5 
4
2 3 5 4 1 
3
1 2 4 3 5 
2
1 2 4 3 5 
1
1 2 3 4 5 
4
1 2 3 4 5 
2
1 2 3 4 5 
2
1 2 3 4 5 
3
1 2 3 4 5 
3
2 3 4 1 5 
3
1 2 3 4 5 
3
1 3 2 4 5 
2
1 2 3 4 5 
3
1 2 3 4 5 
1
1 2 3 4 5 
3
1 2 3 4 5 
1
1 3 4 2 5 
2
1 3 4 2 5 
2
1 2 3 4 5 
2...

result:

ok Correct!

Test #6:

score: 0
Accepted
time: 0ms
memory: 3888kb

input:

10
45 47
3 0 2 0 1 1 1 0 2 0 1 0 0 3 0 0 0 4 0 1 0 0 1 2 1 1 1 0 1 1 1 0 0 0 0 1 0 0 0 1 2 4 1 2 1 2 3
7 1 37 21 3 13 43 22
0
10 23 46 22 40 12 19 47 27 16 42
4 29 19 45 35
10 6 26 2 43 41 7 9 16 42 44
5 39 40 34 46 14
3 34 3 38
8 10 5 38 23 19 37 9 34
0
5 31 29 15 13 35
3 40 4 28
1 7
6 29 12 9 35 2...

output:

33
1 2 7 9 11 6 12 14 16 17 19 20 21 22 23 25 26 27 28 29 5 30 31 32 33 34 3 37 10 4 13 18 24 35 38 39 8 40 15 41 42 43 36 44 45 
39
3 4 8 10 12 13 14 16 17 18 19 7 22 25 24 27 28 29 30 33 20 35 37 38 11 34 39 6 23 40 9 21 5 41 1 42 43 36 44 2 15 26 45 31 32 
36
1 3 4 7 8 9 10 12 13 14 15 16 17 20 2...

result:

ok Correct!

Test #7:

score: 0
Accepted
time: 2ms
memory: 4312kb

input:

1
499 497
1 2 0 2 0 1 0 0 0 2 1 2 0 3 1 2 0 0 0 1 0 1 0 2 1 0 1 0 1 1 1 2 0 1 0 1 0 2 2 3 1 1 2 1 0 0 1 0 2 3 0 1 0 0 2 0 1 2 1 0 0 1 2 0 0 2 0 2 0 1 0 1 0 0 1 0 0 1 1 1 1 1 0 0 0 1 2 3 0 0 0 4 2 2 1 2 2 0 1 0 1 0 2 0 1 0 2 0 0 1 1 1 3 2 0 2 2 2 0 1 1 1 1 1 0 1 0 1 1 1 1 1 2 0 0 1 0 2 1 2 1 2 1 0 1 ...

output:

482
2 4 5 9 11 13 14 15 21 23 30 31 34 41 42 43 48 53 55 58 59 61 63 66 70 74 78 85 89 91 92 94 95 103 104 110 111 112 113 117 120 121 122 124 125 126 135 137 138 139 141 142 143 144 148 153 156 160 164 167 169 171 65 116 172 174 175 176 179 187 188 190 195 197 203 204 205 208 211 214 216 217 223 22...

result:

ok Correct!

Test #8:

score: 0
Accepted
time: 35ms
memory: 11656kb

input:

1
498 499
0 1 1 0 1 0 1 0 0 0 0 2 0 3 1 2 4 0 1 0 1 1 0 0 0 1 1 0 0 2 2 0 1 1 1 0 4 1 1 2 1 0 0 1 2 0 1 2 1 0 1 2 0 2 1 2 2 0 2 2 0 1 0 2 0 0 3 0 1 1 1 1 0 1 0 1 0 0 1 1 0 1 1 0 0 1 0 1 2 1 1 0 1 0 1 0 0 0 1 1 2 0 1 0 2 1 1 2 2 0 0 0 0 2 0 2 1 0 1 0 2 0 1 3 1 1 1 0 1 3 0 1 0 1 0 0 1 3 2 3 2 1 1 0 2 ...

output:

498
35 59 67 74 77 78 79 86 88 90 96 98 108 109 111 113 114 116 117 118 120 129 132 133 143 148 150 157 160 168 170 174 180 181 182 187 193 194 195 196 197 198 199 201 208 209 211 214 216 218 222 226 227 228 172 231 232 233 234 235 239 240 241 245 247 248 250 252 253 256 259 260 263 265 266 268 269 ...

result:

ok Correct!

Test #9:

score: 0
Accepted
time: 0ms
memory: 3932kb

input:

5
99 96
2 0 0 1 1 2 1 0 1 1 1 0 0 0 1 0 1 1 2 1 1 1 1 1 0 1 2 4 0 0 0 2 2 1 1 1 1 1 0 2 0 0 0 1 1 3 0 1 0 0 1 2 1 4 1 2 1 0 1 0 0 2 0 0 0 2 3 2 1 0 1 2 2 0 1 1 0 0 1 0 0 1 2 1 3 1 3 1 3 0 3 0 0 2 2 2
2 14 58
1 55
2 53 69
0
0
1 76
2 23 38
1 41
2 74 54
0
0
2 83 91
0
0
0
1 48
0
0
1 96
2 76 52
1 17
2 51...

output:

48
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 22 24 26 27 28 29 30 31 32 33 34 23 35 36 37 38 39 40 41 43 44 45 46 48 49 50 51 53 54 55 57 58 60 61 62 63 64 65 66 21 68 69 70 71 72 73 74 75 76 77 67 78 79 80 81 82 25 85 86 87 88 42 89 90 91 92 93 47 56 94 83 95 52 96 97 59 84 98 99 
44
1 2 3...

result:

ok Correct!

Test #10:

score: 0
Accepted
time: 0ms
memory: 3868kb

input:

5
99 97
0 2 4 0 0 2 0 1 1 1 0 1 0 3 0 1 1 1 1 0 0 1 0 0 1 2 0 0 1 3 1 2 0 2 1 1 1 3 3 1 2 1 0 1 0 1 0 2 0 0 0 0 1 2 3 1 1 1 0 1 0 1 0 0 1 2 1 2 1 1 1 2 2 3 1 1 0 0 1 1 0 0 1 1 2 1 2 2 0 1 1 1 2 0 1 3 1
2 56 63
2 52 45
4 26 56 80 10
2 27 19
1 81
2 38 64
1 83
1 8
3 14 81 60
3 63 28 15
5 59 33 80 88 56...

output:

72
1 2 3 5 6 7 8 9 10 12 13 14 15 16 19 20 21 22 23 24 25 29 30 31 32 33 35 37 38 39 40 41 43 44 34 45 46 47 48 49 51 53 54 56 57 58 61 63 64 65 66 67 68 69 70 4 71 72 11 17 73 55 74 75 76 77 78 79 80 81 18 26 62 82 83 27 52 84 85 42 60 86 87 50 88 89 90 28 91 92 93 94 95 96 97 36 59 98 99 
67
2 4 7...

result:

ok Correct!

Test #11:

score: 0
Accepted
time: 1ms
memory: 3844kb

input:

5
99 98
4 0 1 1 3 2 0 1 4 0 1 1 2 2 1 2 0 0 1 2 1 2 0 1 1 1 2 0 2 0 0 3 0 2 0 0 1 1 1 0 1 1 1 2 0 1 1 0 1 1 1 0 0 1 0 0 2 1 2 3 3 0 0 0 0 0 1 2 1 1 0 3 0 0 0 1 2 0 0 0 0 1 0 2 2 1 2 1 0 1 0 0 1 1 2 3 3 0
5 72 78 90 7 60
6 69 37 10 41 4 59
10 61 85 79 5 7 58 3 55 1 50
6 59 24 30 26 77 21
2 29 21
10 7...

output:

85
3 4 5 7 8 9 11 12 13 15 17 18 19 20 21 22 24 27 29 30 31 35 36 37 38 40 41 42 45 47 48 50 51 52 53 54 55 46 56 59 61 62 63 64 66 67 68 69 70 72 73 74 25 34 76 16 60 14 77 79 33 80 82 83 10 39 84 85 86 87 88 89 90 49 71 26 44 78 91 58 92 93 81 94 57 1 32 95 96 97 23 75 2 98 28 43 6 65 99 
87
2 3 6...

result:

ok Correct!

Test #12:

score: -100
Wrong Answer
time: 2ms
memory: 3936kb

input:

5
97 100
1 1 1 0 0 1 0 1 1 2 0 1 2 0 1 0 2 3 0 1 0 1 0 1 0 0 1 0 1 2 0 3 2 2 1 0 1 1 2 3 3 1 0 2 1 1 1 2 2 2 0 2 0 3 1 2 2 2 0 1 0 1 1 0 2 0 0 0 0 3 1 0 0 1 0 1 1 0 0 1 1 2 1 2 0 0 1 2 0 1 1 0 2 0 0 1 0 0 2 2
48 80 1 66 89 71 73 40 2 50 99 68 91 31 76 25 67 94 37 6 88 86 28 22 43 62 21 16 17 39 70 1...

output:

94
4 5 6 8 9 10 14 16 3 22 23 25 26 27 29 31 33 34 37 42 43 44 45 46 47 49 53 48 56 57 60 61 62 63 36 50 64 65 58 66 67 68 69 11 70 71 72 73 75 51 30 19 76 13 38 77 78 79 80 81 20 82 1 40 84 7 52 54 83 86 87 88 12 89 32 41 2 85 90 59 91 17 21 92 93 94 39 35 95 96 15 97 
94
1 2 9 13 16 19 20 25 26 27...

result:

wrong answer not a permutation