QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#305788#6668. TrokutiHuasushis0 10ms3864kbC++142.9kb2024-01-16 00:04:162024-01-16 00:04:17

Judging History

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

  • [2024-01-16 00:04:17]
  • 评测
  • 测评结果:0
  • 用时:10ms
  • 内存:3864kb
  • [2024-01-16 00:04:16]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
const int n = 100;
int a[110][110];
int fc[15];
int tmp[6][6], tot;
int fa[210];
int getfa(int v) {
  return v == fa[v] ? v : fa[v] = getfa(fa[v]);
}
int main() {
  ios::sync_with_stdio(false);
  for (int i = 1; i <= 5; ++i) {
    for (int j = i + 1; j <= 5; ++j) {
      tmp[i][j] = ++tot;
    }
  }
  tot = 0;
  for (int i = 1; i <= 5; ++i) {
    for (int j = i + 1; j <= 5; ++j) {
      for (int k = j + 1; k <= 5; ++k) {
        ++tot;
        cout << "? " << i << ' ' << j << ' ' << k << endl;
        int bs = 0;
        cin >> bs;
        fc[tot] = bs;
      }
    }
  }
  for (int mj = 0; mj < (1 << 10); ++mj) {
    int ls[11];
    for (int j = 1; j <= 10; ++j) ls[j] = (mj >> (j - 1)) & 1;
    tot = 0;
    for (int i = 1; i <= 5; ++i) {
      for (int j = i + 1; j <= 5; ++j) {
        for (int k = j + 1; k <= 5; ++k) {
          ++tot;
          if (ls[tmp[i][j]] + ls[tmp[i][k]] + ls[tmp[j][k]] != fc[tot]) goto nxt;
        }
      }
    }
    for (int i = 1; i <= 5; ++i) {
      for (int j = i + 1; j <= 5; ++j) {
        a[i][j] = ls[tmp[i][j]];
        a[j][i] = a[i][j];
      }
    }
    break;
    nxt:;
  }
  for (int i = 6; i <= n; ++i) {
    const int li = i, yi = i + i;
    static mt19937 mt(19260817 ^ 19491001);
    iota(fa + 1, fa + i * 2 + 1, 1);
    deque<int> p;
    for (int j = 1; j < i; ++j) p.emplace_back(j);
		shuffle(p.begin(), p.end(), mt);
    while (p.size() > 1) {
      int u = p[0], v = p[1];
      p.pop_front(), p.pop_front();
      cout << "? " << i << ' ' << u << ' ' << v << endl;
      int bs = 0;
      cin >> bs;
      bs -= a[u][v];
      switch (bs) {
        case 0: case 2: {
          fa[getfa(u)] = fa[getfa(v)] = getfa(bs ? yi : li);
          fa[getfa(u + i)] = fa[getfa(v + i)] = getfa(bs ? li : yi);
          break;
        }
        case 1: {
          fa[getfa(u)] = getfa(v + i);
          fa[getfa(v)] = getfa(u + i);
          p.emplace_back(u);
          break;
        }
      }
    }
    if (!p.empty()) {
			int u = p[0], v = 0, bs = 0;
			for (int j = 1; j < i; ++j) {
				if (j == u) continue;
				if (getfa(j) == getfa(u)) {
					v = j;
					cout << "? " << i << ' ' << u << ' ' << v << endl;
					int bs = 0;
					cin >> bs;
					bs -= a[u][v];
					bs /= 2;
					goto js;
				}
				if (getfa(j) != getfa(u) && getfa(j + i) != getfa(u)) {
					v = j;
					break;
				}
			}
			cout << "? " << i << ' ' << u << ' ' << v << endl;
			cin >> bs;
			bs -= a[u][v] + (getfa(v) == getfa(yi));
			js:
			fa[getfa(u)] = getfa(i * (bs + 1));
			fa[getfa(u + i)] = getfa(i * (2 - bs));
		}
    for (int j = 1; j < i; ++j) {
      a[i][j] = a[j][i] = getfa(j) == getfa(yi);
    }
  }
  cout << "!" << endl;
  for (int i = 1; i <= n; ++i) {
    for (int j = 1; j <= n; ++j) {
      cout << a[i][j];
    }
    cout << endl;
  }
  return 0;
}

詳細信息

Subtask #1:

score: 0
Wrong Answer

Test #1:

score: 100
Accepted
time: 10ms
memory: 3864kb

input:

0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
...

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 1
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 1
? 11 1 3
? 11 9 10
? 11 8 5
? 11 7 4
? 11 6 2
? 12 3 1
? 12 6 1...

result:

points 1.0 points  1.0 correct 2504 queries

Test #2:

score: 100
Accepted
time: 0ms
memory: 3640kb

input:

3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
...

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 1
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 1
? 11 1 3
? 11 9 10
? 11 8 5
? 11 7 4
? 11 6 2
? 12 3 1
? 12 6 1...

result:

points 1.0 points  1.0 correct 2504 queries

Test #3:

score: 100
Accepted
time: 3ms
memory: 3668kb

input:

0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
...

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 1
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 1
? 11 1 3
? 11 9 10
? 11 8 5
? 11 7 4
? 11 6 2
? 12 3 1
? 12 6 1...

result:

points 1.0 points  1.0 correct 2504 queries

Test #4:

score: 100
Accepted
time: 4ms
memory: 3652kb

input:

3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
...

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 1
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 1
? 11 1 3
? 11 9 10
? 11 8 5
? 11 7 4
? 11 6 2
? 12 3 1
? 12 6 1...

result:

points 1.0 points  1.0 correct 2505 queries

Test #5:

score: 100
Accepted
time: 4ms
memory: 3636kb

input:

0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
...

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 1
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 1
? 11 1 3
? 11 9 10
? 11 8 5
? 11 7 4
? 11 6 2
? 12 3 1
? 12 6 1...

result:

points 1.0 points  1.0 correct 2512 queries

Test #6:

score: 100
Accepted
time: 6ms
memory: 3664kb

input:

3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
2
3
3
3
3
3
3
3
3
3
3
3
3
3
3
3
...

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 1
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 1
? 11 1 3
? 11 9 10
? 11 8 5
? 11 7 4
? 11 6 2
? 12 3 1
? 12 6 1...

result:

points 1.0 points  1.0 correct 2511 queries

Test #7:

score: 0
Wrong Answer
time: 3ms
memory: 3580kb

input:

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

output:

? 1 2 3
? 1 2 4
? 1 2 5
? 1 3 4
? 1 3 5
? 1 4 5
? 2 3 4
? 2 3 5
? 2 4 5
? 3 4 5
? 6 3 4
? 6 1 2
? 6 5 3
? 6 5 1
? 7 3 6
? 7 4 5
? 7 1 2
? 7 4 1
? 7 4 2
? 8 5 6
? 8 2 7
? 8 3 1
? 8 4 5
? 8 2 3
? 8 4 2
? 8 4 3
? 9 1 5
? 9 2 8
? 9 4 3
? 9 7 6
? 9 1 2
? 9 7 1
? 10 2 7
? 10 8 4
? 10 3 1
? 10 5 9
? 10 6 3...

result:

wrong answer the graph you report is incorrect