QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#387863#8544. Colorful Graph 2ucup-team027#TL 2681ms59700kbC++143.6kb2024-04-12 22:08:472024-04-12 22:08:47

Judging History

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

  • [2024-04-12 22:08:47]
  • 评测
  • 测评结果:TL
  • 用时:2681ms
  • 内存:59700kb
  • [2024-04-12 22:08:47]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;

namespace std {
	template<>
	struct hash<pair<int, int>> {
	public:
		size_t operator() (const pair<int, int> &x) const {
			return 1000000009LL * x.first + x.second;
		}
	};
}

inline char gc() { // like getchar()
	static char buf[1 << 16];
	static size_t bc, be;
	if (bc >= be) {
		buf[0] = 0, bc = 0;
		be = fread(buf, 1, sizeof(buf), stdin);
	}
	return buf[bc++]; // returns 0 on EOF
}

int readInt() {
	int a, c;
	while ((a = gc()) < 40);
	if (a == '-') return -readInt();
	while ((c = gc()) >= 48) a = a * 10 + c - 480;
	return a - 48;
}

void solve() {
    int n = readInt(), m = readInt();
    vector<vector<int>> g(n);
    unordered_set<pair<int, int>> edges;
    for (int i = 0; i < m; i++) {
        int x = readInt(), y = readInt();
        g[x].push_back(y);
        g[y].push_back(x);
        edges.insert({x, y});
        edges.insert({y, x});
    }
    for (int i = 0; i < n; i++) {
        g[i].push_back((i+1) % n);
    }

    unordered_map<pair<int, int>, int> nxt;
    for (int piv = 0; piv < n; piv++) {
        sort(g[piv].begin(), g[piv].end(), [&](int x, int y){
            if (x < piv && y < piv) return x < y;
            if (x > piv && y > piv) return x < y;
            if (x > piv) return true;
            return false;
        });

        for (int i = 1; i < g[piv].size(); i++) {
            nxt[{g[piv][i-1], piv}] = g[piv][i];
        }
        nxt[{g[piv].back(), piv}] = (piv-1+n) % n;
    }

    /*
    for (auto [p, nn]: nxt) {
        cout << p.first << ' ' << p.second << ' ' << nn << '\n';
    }
    */
    
    vector<vector<int>> pols;
    unordered_set<pair<int, int>> vis;
    for (auto [pp, nxx]: nxt) {
        auto [x, y] = pp;
        if (vis.count({x, y})) continue;
        
        vector<int> pol; pol.push_back(x);
        int curx = x, cury = y;
        while (!vis.count({curx, cury})) {
            vis.insert({curx, cury});
            pol.push_back(cury);
            int nx = nxt[{curx, cury}];
            curx = cury;
            cury = nx;
        }

        /*
        cout << "POLYGON\n";
        for (int i: pol) cout << i << ' ';
        cout << '\n';
        */

        pols.push_back(pol);
    }

    map<pair<int, int>, vector<int>> mpe;
    for (int j = 0; j < pols.size(); j++) {
        auto &pol = pols[j];
        for (int i = 1; i < pol.size(); i++) {
            int x = pol[i], y = pol[i-1];
            if (x > y) swap(x, y);
            if (edges.count({x, y})) {
                mpe[{x, y}].push_back(j);
            }
        }
    }

    int sz = pols.size();
    vector<vector<int>> g2(sz);
    for (auto [pp, ed]: mpe) {
        g2[ed[0]].push_back(ed[1]);
        g2[ed[1]].push_back(ed[0]);
    }

    vector<int> ans(n, -1);
    stack<int> st;
    st.push(0);
    vector<int> vis2(sz);
    while (st.size()) {
        int u = st.top(); st.pop();
        vis2[u] = 1;

        int has0 = 0, has1 = 0;
        for (int i: pols[u]) {
            if (ans[i] == 0) has0 = 1;
            if (ans[i] == 1) has1 = 1;
        }

        int col;
        if (has0 == 0) col = 0;
        else col = 1;

        for (int i: pols[u]) {
            if (ans[i] != -1) continue;
            ans[i] = col;
            col ^= 1;
        }

        for (int v: g2[u]) {
            if (vis2[v]) continue;
            st.push(v); 
        }
    }

    for (int i: ans) if (i) cout << "R"; else cout << "B";
    cout << '\n';
}

signed main(){
    ios::sync_with_stdio(0), cin.tie(0);
    
    int t = readInt();
    while (t--) {
        solve();
    }
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

3
3 0
4 1
1 3
6 3
0 2
2 4
4 0

output:

BBR
RBBR
RRBBRB

result:

ok ok (3 test cases)

Test #2:

score: 0
Accepted
time: 372ms
memory: 3676kb

input:

100000
9 6
2 0
4 6
3 6
0 6
0 7
2 6
3 0
5 2
2 4
2 0
6 3
1 5
4 1
2 4
9 6
3 1
6 4
8 1
3 6
1 6
8 6
3 0
7 4
3 0
4 0
6 4
3 1
7 4
5 1
5 0
3 1
1 4
4 1
1 3
6 3
2 4
4 0
2 0
6 3
3 0
1 3
5 3
7 4
0 5
2 5
5 1
3 5
8 5
4 1
5 1
5 0
1 3
5 7
3 0
8 5
0 2
4 6
0 6
0 3
4 0
8 5
5 1
1 4
5 0
3 1
5 7
3 0
10 7
0 2
9 2
5 8
3 9
...

output:

BRRBRBRBR
BBR
RRBBR
RBBRRR
RBRRRRBRR
BBR
BRBRBRR
BRRBRBR
RBBR
RRBBRB
BRRBRR
BRRRRBR
BRRBRBRR
BBR
BRRRRRBR
BRRBRBRR
BBR
RRBRBRRRBR
RBRRRRBR
RBRBRRBRBR
RBRBRBRRBR
BRRBRRBRBR
BBR
RBRRBRR
BBRRRR
RRBRRRBR
RBBR
BRRBRBR
BRBRBRRRBR
BRBRRBR
RBRBRRBR
BBRRRR
RRBBRB
BBR
BBR
RBRRRBRBR
BRRRBRR
BBRRR
RBRRRBRRBR
BB...

result:

ok ok (100000 test cases)

Test #3:

score: 0
Accepted
time: 259ms
memory: 3688kb

input:

100000
8 4
5 3
5 1
6 1
3 1
7 4
5 0
4 1
4 0
3 1
4 0
8 1
4 7
3 0
3 0
8 1
1 3
3 0
9 4
6 0
3 0
3 1
5 0
7 0
6 2
4 2
0 4
7 3
0 3
0 4
1 3
5 1
3 0
10 4
6 8
5 2
1 5
5 3
5 1
1 4
3 0
9 3
5 0
8 6
6 0
3 0
5 2
1 3
1 4
9 0
6 1
4 2
8 1
1 3
5 0
8 2
3 1
6 1
5 1
3 0
8 3
3 0
7 4
7 5
7 2
5 3
1 3
10 3
8 0
0 3
8 5
9 4
3 0...

output:

BRRBRRBR
BRRBRBR
BRBR
BRBRBBRR
BBR
BBR
BBRRBRBR
BBR
BRRBRRRBR
BBRBRBR
RBBBRB
RBRRBRB
BRBRR
BRRRRBRRBR
RBRBR
BBR
BRBRBRBRR
BBR
RBBRR
BRBRBRBRB
RRBBRB
BBRRBRBR
BRBRB
BRBRBRBR
BRBRR
RBRBBRBR
BBRRRBR
BRBRBRBRBR
RBRRBRBRR
BRBRRBRBR
BRBRBR
BBRRRBR
BBR
BRRBRBRBRB
BRBRBR
BBRBRRRBR
RBBRR
BRRBRRBRBR
RRBBR
RRB...

result:

ok ok (100000 test cases)

Test #4:

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

input:

19452
78 75
50 52
61 64
19 21
21 27
52 54
75 5
47 58
15 13
47 66
69 71
66 68
33 36
27 32
15 17
66 60
74 7
63 61
41 13
45 71
30 28
68 71
18 13
13 42
47 55
76 1
19 32
61 66
5 2
22 24
74 71
42 44
59 47
66 46
26 21
49 52
56 58
54 47
52 48
21 25
19 41
10 42
45 74
48 54
39 41
41 18
75 6
39 33
33 37
31 28
...

output:

BRRRBRBRRRBRRBRRRBRBRRRRBRBRBRRRRRBRRBRRBRRRBRRRRBRBRRBRBRRBRRBRBRBRRBRRBRBRBR
RBRBRBRBRRBRBRRRRBRBRRBRRRBRRRBRRBRRBRBRBRBRBRRRRRBRRRRRBRRBRBRRBRRBRRRRBRBRRRRRRBRRRRBR
RRBRRBRBRRRRRRRBRRRBRRBRRRRBRRBRRBRRBRBRRRBRBRRBRRBRBRRBRBRRRRRBRRRBRRBRRBBR
BRBRRBRBRRRRRRRBRBRBRRBRBRRBRRRBRBRBRBRBRBRRRRBRRRRBRBR...

result:

ok ok (19452 test cases)

Test #5:

score: 0
Accepted
time: 773ms
memory: 3832kb

input:

19457
72 56
1 70
0 70
2 70
19 69
64 42
34 32
55 57
22 68
54 48
26 28
41 23
13 10
68 21
62 59
29 26
53 51
30 41
41 38
15 7
66 64
3 15
23 42
47 54
9 7
6 4
47 42
64 22
67 22
17 3
37 35
23 64
30 38
59 61
24 41
70 17
19 70
30 32
17 19
19 21
14 7
2 17
29 24
6 15
69 21
62 55
9 14
16 3
25 29
15 4
53 50
35 3...

output:

RBRRRBRRRBRBRBRBRBRBRRRBRBRRBRBRRRBRRBRBRRRBRBRBRBRRRBRBRRBRBRBRRRBRBRRB
BRRBRBRBRBBRRBRBRBBRRBRBRBBRRBBRBRRBRBRBRBR
RRBRBRBRBRBRBRBRBRBRBBRRBRBRBRBRBRBRRBRRBRBRBRRBRRBRBRBRBRBRBRBRBRBRRBRR
RRBRRBBRBBRBRRBRRBRBBRBRRBRBRBRRBRBBRRRRRBRBRBRBRBRBRBRRBRBRBRBRBBRRRRBBRBRBRRBRBRRBRBR
BBRRBRRBBRBRBRRRBRBRBR...

result:

ok ok (19457 test cases)

Test #6:

score: 0
Accepted
time: 1335ms
memory: 4476kb

input:

2011
404 401
326 324
85 82
297 38
198 201
196 205
299 8
206 188
326 329
280 277
378 5
155 153
367 360
282 277
378 6
375 377
315 317
92 81
227 229
174 176
141 145
276 272
218 216
43 45
205 188
163 221
205 193
223 226
307 317
387 383
23 33
52 50
199 201
367 358
394 396
177 179
170 167
104 102
263 265
...

output:

BRBRRRBRRBRBRBRBRRRBRBRRRRRBRRBRBRBRRBRRRBRRBRRBRRRBRBRRBRRRRRBRRRRBRBRBRRBRRRRRRBRRBRRBRBRBRRRBRRBRRRBRRBRRRRBRRRRBRBRBRBRBRBRRRRBRRRBRRBRBRRRRBRRBRBRRBRBRBRRRRBRRBRBRRBRRRRBRRBRRBRBRRBRRRRBRBRRBRRRBRRRBRRBRBRRRRRBRRRBRBRBRBRRBRRRBRRBRBRBRRBRRRRRRRBRBRRRBRRBRBRRBRRRRBRRBRBRBRBRBRRRBRBRBRRBRRBRRBRRB...

result:

ok ok (2011 test cases)

Test #7:

score: 0
Accepted
time: 786ms
memory: 4672kb

input:

1958
908 775
369 374
638 644
308 310
686 758
596 593
432 410
730 732
556 476
356 354
711 742
149 144
582 609
714 716
895 667
831 837
37 10
17 13
880 882
453 457
266 269
297 301
577 113
114 576
115 166
716 727
130 163
708 745
337 317
250 303
712 714
893 668
344 351
319 322
276 264
107 109
567 466
415...

output:

BRRBRRBRRRBRBRBRBRBRBRBRRBBRBRRBRBRRBRRRBRBRBBRRBRRBRRBRBRRBRRRBRRRRBRRBRRBRBRBRRBRBRRRBRBRRBRRBRRBRBBRRBRRBRRBRRRRRBBRBRRRRBRBRRBRBRRBRRRRBRRRRBBRBRRBBRBRRBRRBRRBRBRBRBRRRBRRBRRRBRBRRBRBRBRBRRBRRRRBBRRRBRRRBRBRRBRRBRBRRBRBRRRBRBRRRBRBRRRRBRRRRRBRRRBRBRRBRBBRRRBRBRRRBRBRRRBRBRBRBRBRRBRRRBRBRBRBRRBRR...

result:

ok ok (1958 test cases)

Test #8:

score: 0
Accepted
time: 1594ms
memory: 10392kb

input:

204
1066 1063
466 462
569 566
239 241
125 134
418 422
147 142
99 103
380 305
100 103
589 585
336 315
126 134
176 1042
995 431
966 975
857 854
112 110
841 862
1018 1015
202 266
860 853
86 94
254 252
454 448
523 675
864 867
221 216
710 707
184 286
984 931
70 65
165 31
634 642
557 555
763 770
537 529
4...

output:

RRBRRRBRBRRBRRBRRBRRBRRBRRBRRBRBRRRBRRBRRBRBRBRRBRRBRBRBRBRRBRRRRRRBRBRBRBRBRBRBRRRBRRBRRBRBRBRRBRRBRRBRRBRRBRBRRBRRRBRRRBRRRRRRRRBRRRBRRRBRRBRRBRBRBRBRBRBRRBRBRRRBRRRBRBRBRBRBRRBRRRBRRRRBRBRBRBRBRBRBRRRRRRBRBRRRRBRRRRBRBRRBRBRBRRBRBRBRBRBRBRRBRBRRRBRBRRBRBRBRBRRRRRBRBRBRBRBRBRBRRBRRRBRBRRRRRBRRRBRB...

result:

ok ok (204 test cases)

Test #9:

score: 0
Accepted
time: 902ms
memory: 9836kb

input:

203
2148 1719
1557 1562
1834 1826
661 646
1733 1747
668 670
1449 1497
256 254
1571 1569
1726 1701
142 135
1981 1979
1966 1992
2107 2104
1209 1196
752 895
2035 2033
621 618
3 6
2093 2110
437 479
641 643
566 519
640 628
626 678
1694 1726
1520 1522
1434 1430
1127 1130
2021 2014
1349 1347
378 383
1475 1...

output:

RBRRRBRRBRBRBBRBRRRRRBRBRRRBBRRRRRBRBRBRBRRRRRBBBRRRRRBBRRBBRRRBRRBRRRRRBRRRRRBRRBRBRBRRBRBBBRRRBRBRBRRRRRRRBRBRBRRBRRBRRRRBRBRRRBRBRBRBRRRRBRRBRBRBRRBRRRBRBRRBRRRBRBRRBRBRBRRRRRBRRBRBRRBRBRRRBRBRRRBRBRBRBRRBRRBBRRRBRBBRBBRBBRRBBRRRRRBRBBRRBRBRRBRBRBRBRRBRRRBRRBRBRBRBRBBBRRRBRBRRBBRRRBRBRBRBRBRBRRRR...

result:

ok ok (203 test cases)

Test #10:

score: 0
Accepted
time: 2681ms
memory: 59700kb

input:

28
75972 75969
72982 72984
57195 57198
62938 62906
8473 8556
37842 37858
33380 33354
1503 1501
6490 6468
3231 3212
66806 66785
66178 66191
16644 16646
28283 28285
7797 7805
27304 50764
62274 62338
70175 70182
37760 37762
10872 10845
2554 2552
22131 22129
25754 25685
30543 30473
48058 48056
49029 490...

output:

RRBRBRBRRRBRBRRBRRBRRBRRBRRBRBRBRRBRBRRBRBRBRBRRRBRBRRRRBRRBRBRRRRBRRBRBRBRBRRBRBRRBRRBRBRRRRRBRRBRBRRRBRBRBRRRRBRBRRBRRRBRBRRBRBRBRBRBRRRRRBRBRRBRRBRBRBRBRBRRRBRBRBRBRBRBRRRBRBRRRBRRRBRRRBRBRRRRRRBRBRRBRRRBRRRBRBRRBRBRBRRRRBRBRRRRBRRRBRRBRBRBRRRRBRRRBRBRBRBRRRBRBRBRBRBRRRRRRRRRRRRBRRBRBRBRRRBRRRRBR...

result:

ok ok (28 test cases)

Test #11:

score: 0
Accepted
time: 1165ms
memory: 52984kb

input:

22
51680 33612
36516 36505
51193 51188
35606 35610
33625 33614
40437 40292
42236 42238
10393 10282
8774 8772
51621 51618
45268 45266
38275 38351
10322 10324
1643 1640
24399 24397
5679 5647
4270 4267
20292 20262
20865 20860
36134 36075
19151 19148
47570 47564
9019 8996
11628 11631
29914 29916
1038 10...

output:

RRBRBRRBRBRBBRRBRBRRRBRRBRRRBRRBRRBRRRRBRRBRRBRBRRBRBRBRRBBRBRBRRBRBBRRBRRBRRBRRBRRBRBRRBRRBRBRRBBRRBRRBBRRBRBRRBRRBRBBRBRBRRRBBRRRBRBRBRBRBBRRRBRBRRBRRBRRBRRRRRBRRRRBRRBRBRBRBRRRBRBRRRRRBRBRBRBRBRRRRBRRRBBRRBRBRRBRRRBRRRBRBRRRRRBRRBRRBBRRBRRRRRBBBBRRRBRBBRBRBBRRBBRRBRBRRRBRBBBRRRBRRRBRRBRBRRRBRBRBR...

result:

ok ok (22 test cases)

Test #12:

score: -100
Time Limit Exceeded

input:

19
136603 136600
85502 85506
69490 69362
56462 56450
110823 110787
116554 116560
124319 124410
23116 23109
4083 4088
57777 57784
70730 71751
116728 116719
131667 12876
37328 37322
41430 41432
65505 65508
117991 118000
34432 34430
43863 43866
22396 22399
24787 24780
75822 75672
6394 6392
101553 10154...

output:

RBRRBRRBRRBRBRRRBRBRRBRBRBRBRBRRRBRBRRBRBRRRRBRBRRBRRRRBRRBRRRBRRBRBRRBRRBRBRRRRBRRBRBRBRBRRBRBRRBRBRRBRRBRRBRBRBRBRRBRRRBRBRBRBRRRBRRBRBRRRBRBRBRRBRRRRRRBRBRRBRRRBRBRBRRRRBRBRBRBRBRBRBRRBRBRBRBRRBRRBRRRBRRBRRRRRRRRRRBRRBRRBRBRRRBRBRRBRRRBRBRBRBRRBRRBRRRBRBRBRRRBRBRRBRBRRBRBRRBRRRRBRBRBRBRRRBRRBRBRB...

result: