QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#731287#9565. Birthday Giftucup-team5226#TL 988ms11252kbPython31.7kb2024-11-10 01:45:462024-11-10 01:45:46

Judging History

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

  • [2024-11-10 01:45:46]
  • 评测
  • 测评结果:TL
  • 用时:988ms
  • 内存:11252kb
  • [2024-11-10 01:45:46]
  • 提交

answer

for _ in range(int(input())):
    S = input()
    # print(S)
    dp = [None, None, True]
    for c in S:
        l = [float("inf"), float("inf")]
        r = [-float("inf"), -float("inf")]
        f = False
        for k in range(2):
            if c != str(1 - k):
                if dp[2]:
                    l[k] = min(l[k], 1)
                    r[k] = max(r[k], 1)
                if dp[k] is not None:
                    if dp[k][0] % 2:
                        if dp[k][0] >= 3:
                            l[k] = min(l[k], dp[k][0] - 1)
                        else:
                            f = True
                            if dp[k][1] >= 3:
                                l[k] = min(l[k], 2)
                        if dp[k][1] >= 3:
                            r[k] = max(r[k], dp[k][1] - 1)
                    else:
                        l[k] = min(l[k], dp[k][0] + 1)
                        r[k] = max(r[k], dp[k][1] + 1)
                if dp[1 - k] is not None:
                    if dp[1 - k][0] % 2:
                        l[1 - k] = min(l[1 - k], dp[1 - k][0] + 1)
                        r[1 - k] = max(r[1 - k], dp[1 - k][1] + 1)
                    else:
                        l[1 - k] = min(l[1 - k], dp[1 - k][0] - 1)
                        r[1 - k] = max(r[1 - k], dp[1 - k][1] - 1)
        dp = [
            (l[0], r[0]) if l[0] <= r[0] else None,
            (l[1], r[1]) if l[1] <= r[1] else None,
            f,
        ]
        # print(dp)
    ans = float("inf")
    if dp[2]:
        ans = 0
    if dp[0] is not None:
        ans = min(ans, dp[0][0])
    if dp[1] is not None:
        ans = min(ans, dp[1][0])
    print(ans)

詳細信息

Test #1:

score: 100
Accepted
time: 15ms
memory: 10576kb

input:

5
0110101
01020102
0000021111
1012121010
0100202010

output:

3
4
0
6
0

result:

ok 5 number(s): "3 4 0 6 0"

Test #2:

score: 0
Accepted
time: 856ms
memory: 10568kb

input:

50000
1010110101
1010101010
0101010101
0101010010
0101010010
1010101010
0101001010
1010010010
0100101010
1010101001
1010100101
0101010100
0100101011
0101101010
1011010110
1011010101
1010010101
1010010010
0101010101
0010101010
0101011010
0100101010
1010101010
1010010101
1010101101
1101010101
10100101...

output:

0
10
10
4
4
10
0
4
4
6
2
8
2
2
0
4
2
4
10
8
2
4
10
2
4
8
2
8
8
4
8
4
4
6
4
4
4
6
10
10
2
2
0
10
8
10
0
10
10
10
4
10
8
10
0
8
4
0
8
2
8
0
6
2
8
10
4
10
10
2
10
2
10
8
6
4
2
8
8
0
8
10
8
10
8
10
2
6
10
4
10
8
10
4
10
6
10
10
10
6
6
6
4
10
10
10
2
2
8
10
6
10
10
8
4
10
6
10
2
2
8
2
10
4
6
0
10
4
6
2
1...

result:

ok 50000 numbers

Test #3:

score: 0
Accepted
time: 763ms
memory: 10728kb

input:

5000
1010101010101010101110101010101010100101010101010101010110101010101010101010101010101010101010101010
0101010101010101010101010101101010101010101010101010101010101010101010101010100101010101010110101010
010101010101010101010101010101010101010101010101010101010101010101010100101010101010101010101...

output:

58
16
44
26
2
30
62
14
16
68
44
78
58
54
52
4
22
60
12
60
12
82
64
68
44
4
34
12
82
16
64
12
14
46
48
12
94
12
82
50
30
40
8
88
62
20
2
46
86
36
16
20
18
74
66
36
80
98
26
0
30
72
40
70
28
80
52
18
94
62
32
26
18
92
44
80
48
4
28
32
34
50
80
54
80
32
62
62
76
70
78
16
16
2
2
58
46
18
56
26
36
56
76
...

result:

ok 5000 numbers

Test #4:

score: 0
Accepted
time: 755ms
memory: 10620kb

input:

500
01010101010101010101010101010101010101010101010101010101010101010101001010101010101010101010110101010101010101010101010101010101010101010100101101010101010010101010101010101010101010101010101010101010101010101010101010101101010101010101010101010101010101010101010101010101001010101010101001010100...

output:

28
12
76
174
24
124
142
142
142
194
216
70
12
176
18
310
16
188
38
42
164
110
162
4
12
24
2
96
206
4
238
64
64
28
50
54
278
182
122
86
4
76
44
146
118
122
276
268
148
32
78
90
202
40
20
240
128
116
228
282
36
178
160
88
2
20
114
70
248
68
54
18
18
210
46
126
26
52
0
298
6
16
160
32
92
56
106
126
246...

result:

ok 500 numbers

Test #5:

score: 0
Accepted
time: 783ms
memory: 10652kb

input:

50
101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101...

output:

836
3994
352
3984
1826
568
2088
4076
1750
1258
532
3036
1718
1106
1002
478
1838
2030
422
4210
828
2088
2930
4044
1406
2388
3586
2018
1976
1026
5092
4154
3478
1018
1998
4014
718
2852
6070
2518
6380
4826
170
1876
1096
3914
1692
574
4612
802

result:

ok 50 numbers

Test #6:

score: 0
Accepted
time: 718ms
memory: 10540kb

input:

50
010101010101101110100100101010101100010100110100101001011010101000100101001010100101101010001011010110010101010101010101011011000010001001010101010110101010111010011010101010100101001010101010101100101010101010100101010101010100011101110101010011010101011010110100110101010010010101101101011001010...

output:

152
84
110
60
218
124
190
198
76
98
202
234
126
160
236
134
44
324
176
136
178
156
46
220
8
106
18
136
346
74
30
104
310
264
160
224
198
218
314
166
166
54
82
246
242
62
164
26
336
124

result:

ok 50 numbers

Test #7:

score: 0
Accepted
time: 604ms
memory: 11252kb

input:

2
0101010101010101010101010101010010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010...

output:

6648
174

result:

ok 2 number(s): "6648 174"

Test #8:

score: 0
Accepted
time: 988ms
memory: 10692kb

input:

50000
0100202010
0101221101
0120120101
1210102101
1210101020
1020210101
0200101020
1010210120
0121012010
0212101010
0201010120
1101010221
0012101020
1110101221
1010121201
1202010101
0210012101
0210010102
2101210101
0101002201
0102101210
1020101201
1201002101
0101022010
0201101012
1210010210
20120101...

output:

0
4
2
0
6
0
2
0
0
4
4
4
4
2
2
4
2
2
6
4
0
2
2
0
0
0
2
2
0
4
2
0
0
4
2
4
6
6
4
0
2
4
2
2
0
4
6
6
0
2
4
0
4
4
4
2
0
4
2
0
6
4
6
0
0
4
4
0
6
4
0
0
2
0
6
6
4
0
6
0
0
0
6
2
2
4
2
6
2
0
6
6
2
0
6
2
0
6
4
6
2
0
4
2
0
4
0
6
4
2
6
4
6
2
0
2
4
0
0
0
0
0
2
0
0
0
2
2
4
4
0
4
0
4
4
0
0
4
4
4
0
0
4
2
2
0
2
2
4
2
...

result:

ok 50000 numbers

Test #9:

score: 0
Accepted
time: 878ms
memory: 10700kb

input:

5000
1010101012010101010112010120120102010110100101012101010100101010210101010201010100121010101201010110
0101010101102102010101010101010101010101012012210101010120101010101010120201010102010101010100012011
010201010101212010110201201010101210101010101010101010101101010110121010100101010101021010101...

output:

12
38
12
52
10
0
6
0
34
26
14
0
10
0
14
22
6
30
20
0
2
0
6
0
0
0
16
0
4
0
0
36
4
30
46
14
14
0
26
18
14
30
30
6
0
10
0
28
0
16
26
12
2
28
40
2
2
26
44
0
2
14
18
20
0
8
0
0
40
8
4
4
46
52
2
20
6
6
16
38
38
26
12
0
26
10
0
0
10
36
8
16
16
16
0
0
12
28
0
30
14
22
0
38
22
20
14
26
26
10
30
34
8
20
6
26
...

result:

ok 5000 numbers

Test #10:

score: 0
Accepted
time: 965ms
memory: 10692kb

input:

5000
1210201012021010102101010101010101010102011010220101021010122112010101201012211201001220101020120101
1020102101011012200110101012021001010110101012010221010100222010201010121101010101201010201012221200
101010210110120101010210222101002102102100201012110101201010101101010220101010221001201010201...

output:

0
0
0
0
0
0
0
20
0
0
0
0
0
0
20
0
0
0
2
0
2
4
6
0
0
0
0
0
0
0
16
16
0
0
0
0
0
0
0
0
0
0
12
0
0
0
0
0
0
0
0
0
22
12
0
12
12
10
0
0
0
0
0
0
0
0
0
10
6
0
0
0
18
6
0
0
16
0
0
0
0
0
0
0
2
0
22
0
0
2
0
0
0
6
0
4
0
24
0
6
6
2
0
0
0
0
0
0
12
0
0
0
0
0
26
0
0
0
0
0
0
0
0
4
0
0
26
0
0
0
12
0
0
0
4
0
0
4
12
0
...

result:

ok 5000 numbers

Test #11:

score: 0
Accepted
time: 881ms
memory: 10604kb

input:

500
01010101120101010101010101010101010101210101010101010101010101010101010101010101010101010101010101010102010101010101010101010101021010101010101010101201201010101010102201010110101101010120101010101010101010101010120101020101010101010102101010101010101210101012010101020101011010101010101010101010...

output:

138
178
0
0
30
0
0
68
56
174
0
0
38
72
46
0
0
250
266
58
140
122
124
24
98
0
0
0
126
106
34
64
6
132
0
20
90
370
86
134
12
308
106
158
8
98
128
0
30
52
100
218
222
0
0
100
36
38
34
50
110
0
114
42
148
92
94
138
142
0
90
0
0
76
176
0
148
0
250
92
114
102
26
0
0
156
52
0
104
0
32
18
46
84
0
8
64
0
72
...

result:

ok 500 numbers

Test #12:

score: 0
Accepted
time: 771ms
memory: 10532kb

input:

500
10101010101010101010101010101001010101001010101010101010101010101010101001010101010101010101010101000101010101010101010101010100101010010010101001010101010100101010101010110101011101010101010101010101010101010101010101011010101010101010101010120101010101010201010101021010101010101010101010101010...

output:

16
30
136
200
304
56
20
88
10
36
64
158
92
196
30
298
314
248
0
158
144
310
166
120
10
0
76
232
20
2
128
100
126
154
58
102
116
16
214
62
212
208
44
14
186
22
0
52
118
28
94
140
130
58
94
214
148
34
56
192
62
82
28
100
58
132
36
202
6
92
0
120
192
166
144
52
76
172
68
254
14
58
274
94
226
162
42
44
...

result:

ok 500 numbers

Test #13:

score: -100
Time Limit Exceeded

input:

500
10101010202010101010120201012010101010101010101010101201201010101010101010102210101010122121210101010210210101010101012010101010102201210101010102220102120101010101010122101210120121010120101010101020101201020201020101202201010102220101010101010101101012010101202012210101210101010101010101210101...

output:

0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
20
0
0
0
0
0
0...

result: