QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#578639#9319. Bull FarmWQhuanmTL 188ms25344kbC++172.2kb2024-09-20 20:35:232024-09-20 20:35:23

Judging History

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

  • [2024-09-20 20:35:23]
  • 评测
  • 测评结果:TL
  • 用时:188ms
  • 内存:25344kb
  • [2024-09-20 20:35:23]
  • 提交

answer

// #pragma GCC optimize(2, "Ofast", "inline")
#include <bits/stdc++.h>
using namespace std;
#define ll long long
typedef pair<int, int> pii;
#define endl "\n"
const int N = 2010, M = 1e6 + 5;

int n, m, Q;
int t[N][N], d[N], ok[N];
bitset<N> bit[N];
void add(int x, int y) {
  for (int i = 1; i <= n; ++i)
    if (bit[i][y]) bit[i] |= bit[x];
}
void mysolve() {
  cin >> n >> m >> Q;
  string s;
  for (int i = 1; i <= m; ++i) {
    cin >> s, ok[i] = 0;
    vector<int> tmp(n + 1);
    for (int j = 0; j < (int)s.size(); j += 2) {
      int a = s[j] - 48, b = s[j + 1] - 48, x = a * 50 + b;
      t[i][(j >> 1) + 1] = x, tmp[x]++;
      if (tmp[x] > 2) ok[i] = -1;
      else if (tmp[x] == 2) {
        if (!ok[i]) ok[i] = x;
        else ok[i] = -1;
      }
    }
  }
  vector<array<int, 4>> ask;
  for (int i = 1; i <= Q; ++i) {
    cin >> s;
    for (int i = 0; i < (int)s.size(); i += 2) {
      int a = s[i] - 48, b = s[i + 1] - 48;
      d[i >> 1] = a * 50 + b;
    }
    ask.push_back({d[2], d[0], d[1], i});
  }
  sort(ask.begin(), ask.end());
  for (int i = 0; i <= n; ++i) bit[i].reset(), bit[i][i] = 1;
  int j = 0;
  vector<int> ans(Q + 1);
  for (int i = 1; i <= m; ++i) {
    while (j < (int)ask.size() && ask[j][0] < i) {
      auto [tim, a, b, id] = ask[j++];
      ans[id] = bit[b][a];
    }
    if (!ok[i]) {
      for (int k = 1; k <= n; ++k) add(k, t[i][k]);
    } else if (~ok[i]) {
      vector<int> now;
      for (int k = 1; k <= n; ++k)
        if (t[i][k] == ok[i]) now.push_back(k);
      set<int> mex;
      for (int k = 1; k <= n; ++k) mex.insert(t[i][k]);
      for (int k = 1; k <= n; ++k)
        if (!mex.count(k)) {
          for (auto v : now) add(v, k);
          break;
        }
    }
  }
  while (j < (int)ask.size()) {
    auto [tim, a, b, id] = ask[j++];
    ans[id] = bit[b][a];
  }
  for (int i = 1; i <= Q; ++i) cout << ans[i];
  cout << endl;
}

signed main() {
#ifdef DEBUG
  freopen("in.in", "r", stdin);
  freopen("out.out", "w", stdout);
#endif
  std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0); // 使用read请把解绑注释了
  int t = 1;
  cin >> t;
  while (t--) {
    mysolve();
  }
  return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

2
5 2 4
0305040201
0404040404
030300
020500
050102
020501
6 2 4
030603010601
010203060504
030202
060402
050602
060401

output:

1011
0100

result:

ok 2 lines

Test #2:

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

input:

1
3 3 6
020202
030301
030201
020102
030203
010201
010303
020303
010202

output:

010101

result:

ok single line: '010101'

Test #3:

score: 0
Accepted
time: 157ms
memory: 5736kb

input:

200
10 10 5000
01060:04020305080709
0103070:060204050908
09070503080401060:02
050308010204090:0607
03010502040607080:09
03080109020504060:07
06050:09040302080107
07080305010409060:02
030809010:0204060507
0:060908070201050304
060700
090:03
09080:
070405
010703
0:0100
080601
030600
070206
0:0:09
08040...

output:

011110001101101111111111111111111101111111110111011110110110111011010111111111111111111101111111111110111111110111111111111101111111111110111111111111111111110001100111111111111111111111111011101111111111111111111111111111111111111111011011110100111110111111110111111100111111101110111111111101111110...

result:

ok 200 lines

Test #4:

score: 0
Accepted
time: 188ms
memory: 25344kb

input:

1
2000 1 1000000
M=:]A@8UAY7W2JJ4KEHIA[HSCQ1ENSC`JXR;F3PJ:_@41P9Z=9HR8P<<:DUXRR9^WOQFL?NZP6S@=J0^WE32=6;\U0?88]Q_RNPUMT6YU<4<S]H?:7OCQYOT4YAV1^764ENWSDBED>M7A:BI>KSIR48JQ9B=N\5T3N4A2aF0@>3TI81<G7;YE>W`NMP<:IT4CI3D0=GZC3I\CLQJQBA9BDIS9SAM55KaVA<Z@D=>:Y?CQHUQ5U3a6UVI8OKX9_FAF^7=5M85;<0;8YPAM<7Z7PP7A=N...

output:

000101000101100010001000000010010110000001000001001100000000010000100001000000101100000000010000001000000001110000010110100000111100100000001000000000011001010001000001001000100000000100011001100110010000010000101100000011111000000010000101010010000000010101000001010111100000100000000000000101000100...

result:

ok single line: '000101000101100010001000000010...0101000101000000000010101001000'

Test #5:

score: -100
Time Limit Exceeded

input:

1
2000 2000 1000000
FVAaH7GRPO;_11Da5J18@3SMG==\G8E8S^6:M4L0JH>MN5IXT>2<7WJ3U8LVJS=;;3F13>0D0>VOIIU@EPHG6ABL6;K?T1PXDERLG07]5C9^GDKG<SBMIW;`4W8P3=469TIPKH0O34523_J5C2MJ17D25Z@=K8H@M>WK<CMK7EO]BPD7B6AW741J5YIHIa1:ERSG>L3N2^F3<4F`DLE@2AA5=8GZK6:192FB736[WMV7:^DA2C:<LK040VJBM3M]WXU50`407TR_?PLF@5VL7OSL...

output:


result: