QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#113715 | #5668. Cell Nuclei Detection | UFRJ | AC ✓ | 5649ms | 239764kb | C++20 | 2.7kb | 2023-06-19 06:49:07 | 2023-06-19 06:49:09 |
Judging History
answer
#include "bits/stdc++.h"
#define watch(x) cout << (#x) << " is " << (x) << endl
using namespace std;
using lint = int64_t;
const int mx = 2e3 + 1;
vector<vector<set<int>>> grid;
struct bipartite_matching {
int N, M, T;
vector<vector<int>> adj;
vector<int> match, seen;
bipartite_matching(int a, int b) : N(a), M(a + b), adj(M),
match(M, -1), seen(M, -1), T(0) {}
void add_edge(int a, int b) {
assert(0 <= a && a < N && b + N < M && N <= b + N);
adj[a].push_back(b + N);
}
void shuffle_edges() { // useful to break some hairy tests
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
for (auto& cur : adj)
shuffle(cur.begin(), cur.end(), rng);
}
bool dfs(int cur) {
if (seen[cur] == T) return false;
seen[cur] = T;
for (int nxt : adj[cur])
if (match[nxt] == -1) {
match[nxt] = cur, match[cur] = nxt;
return true;
}
for (int nxt : adj[cur])
if (dfs(match[nxt])) {
match[nxt] = cur, match[cur] = nxt;
return true;
}
return false;
}
int solve() {
int res = 0;
while (true) {
int cur = 0; ++T;
for (int i = 0; i < N; ++i)
if (match[i] == -1) cur += dfs(i);
if (cur == 0) break;
else res += cur;
}
return res;
}
};
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int t, n, m;
cin >> t;
while(t--) {
grid.clear();
grid.assign(mx, vector<set<int>>(mx));
map<int,int> area;
cin >> m >> n;
bipartite_matching bp(n+1, m+1);
int x1, x2, y1, y2, seq = 0;
for(int k = 0; k < m; k++) {
cin >> x1 >> y1 >> x2 >> y2;
int id = ++seq;
int curArea = 0;
for(int i = x1; i < x2; i++) {
for(int j = y1; j < y2; j++) {
grid[i][j].insert(id);
curArea++;
}
}
area[id] = curArea;
}
for(int k = 0; k < n; k++) {
cin >> x1 >> y1 >> x2 >> y2;
unordered_map<int,int> interArea;
for(int i = x1; i < x2; i++) {
for(int j = y1; j < y2; j++) {
for(auto &id : grid[i][j]) {
interArea[id]++;
}
}
}
for(auto &id : interArea) {
int key = id.first, curArea = id.second;
if(curArea*2 >= area[key]) {
// cout << "Green: " << k << " Red: " << key << endl;
bp.add_edge(k, key);
}
}
}
cout << bp.solve() << endl;
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 105ms
memory: 191024kb
input:
3 2 2 1 1 3 3 3 3 5 5 2 2 4 4 4 4 6 6 2 3 1 1 3 3 3 3 5 5 1 3 3 5 2 1 4 5 3 1 5 3 3 3 1 1 2 2 2 2 3 3 3 3 4 4 1 1 3 3 2 2 4 4 3 3 5 5
output:
0 1 3
result:
ok 3 lines
Test #2:
score: 0
Accepted
time: 107ms
memory: 190988kb
input:
3 2 2 1 1 3 3 3 3 5 5 2 2 4 4 4 4 6 6 2 3 1 1 3 3 3 3 5 5 1 3 3 5 2 1 4 5 3 1 5 3 3 3 1 1 2 2 2 2 3 3 3 3 4 4 1 1 3 3 2 2 4 4 3 3 5 5
output:
0 1 3
result:
ok 3 lines
Test #3:
score: 0
Accepted
time: 1196ms
memory: 239644kb
input:
5 50000 50000 0 0 4 4 4 0 8 4 8 0 12 4 12 0 16 4 16 0 20 4 20 0 24 4 24 0 28 4 28 0 32 4 32 0 36 4 36 0 40 4 40 0 44 4 44 0 48 4 48 0 52 4 52 0 56 4 56 0 60 4 60 0 64 4 64 0 68 4 68 0 72 4 72 0 76 4 76 0 80 4 80 0 84 4 84 0 88 4 88 0 92 4 92 0 96 4 96 0 100 4 100 0 104 4 104 0 108 4 108 0 112 4 112 ...
output:
50000 50000 0 50000 3150
result:
ok 5 lines
Test #4:
score: 0
Accepted
time: 626ms
memory: 234684kb
input:
5 50000 50000 0 0 1 1 1 0 2 1 2 0 3 1 3 0 4 1 4 0 5 1 5 0 6 1 6 0 7 1 7 0 8 1 8 0 9 1 9 0 10 1 10 0 11 1 11 0 12 1 12 0 13 1 13 0 14 1 14 0 15 1 15 0 16 1 16 0 17 1 17 0 18 1 18 0 19 1 19 0 20 1 20 0 21 1 21 0 22 1 22 0 23 1 23 0 24 1 24 0 25 1 25 0 26 1 26 0 27 1 27 0 28 1 28 0 29 1 29 0 30 1 30 0 ...
output:
50000 25050 12500 16000 8000
result:
ok 5 lines
Test #5:
score: 0
Accepted
time: 523ms
memory: 211720kb
input:
5 50000 50000 0 0 2 4 4 0 7 1 8 0 10 1 12 0 15 3 16 0 19 1 20 0 22 2 24 0 26 4 28 0 30 4 32 0 36 3 36 0 40 1 40 0 44 1 44 0 47 2 48 0 49 3 52 0 54 1 56 0 59 4 60 0 64 3 64 0 68 3 68 0 70 1 72 0 76 4 76 0 80 3 80 0 84 4 84 0 87 2 88 0 90 1 92 0 94 4 96 0 98 1 100 0 104 1 104 0 107 2 108 0 110 4 112 0...
output:
10594 10779 10618 10381 10779
result:
ok 5 lines
Test #6:
score: 0
Accepted
time: 5649ms
memory: 239764kb
input:
5 50000 50000 0 0 4 4 1 0 5 4 2 0 6 4 3 0 7 4 4 0 8 4 5 0 9 4 6 0 10 4 7 0 11 4 8 0 12 4 9 0 13 4 10 0 14 4 11 0 15 4 12 0 16 4 13 0 17 4 14 0 18 4 15 0 19 4 16 0 20 4 17 0 21 4 18 0 22 4 19 0 23 4 20 0 24 4 21 0 25 4 22 0 26 4 23 0 27 4 24 0 28 4 25 0 29 4 26 0 30 4 27 0 31 4 28 0 32 4 29 0 33 4 30...
output:
50000 50000 50000 50000 49600
result:
ok 5 lines
Test #7:
score: 0
Accepted
time: 20ms
memory: 191020kb
input:
1 4 4 1 1 3 3 2 1 4 3 1 2 3 4 2 2 4 4 2 1 4 3 3 2 5 4 1 2 3 4 2 3 4 5
output:
3
result:
ok single line: '3'