QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#742454#8058. Binary vs Ternaryquark404#WA 80ms10648kbPython33.2kb2024-11-13 16:38:482024-11-13 16:38:51

Judging History

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

  • [2024-11-13 16:38:51]
  • 评测
  • 测评结果:WA
  • 用时:80ms
  • 内存:10648kb
  • [2024-11-13 16:38:48]
  • 提交

answer

ans = []

def count_leading_zero(s: str) -> int:
    res = 0
    for c in s:
        if (c == '0'): res += 1
        else: break
    return res

def modify(s: str, l: int, r: int, base: int = 0) -> str:
    assert(base == 0)
    if (l >= r): return s
    src = s[l:r + 1]
    src = int(src, base=3)
    src = bin(src)[2:]
    ans.append((l + 1 + base, r + 1 + base, f"before: {s}, after: {s[:l] + src + s[r + 1:]}"))
    return s[:l] + src + s[r + 1:]

def erase_trailing_zero(s: str, base: int) -> str:
    l, r = len(s) - 1, len(s) - 1
    while (l >= 0 and s[l] == '0'): l -= 1
    l += 1
    assert(l >= 1)
    return modify(s, l, r, base)

def change_last_digit(s: str, base: int):
    l = len(s) - 2
    while (s[l] == '0'): l -= 1
    assert(l >= 1)
    assert(len(s) >= 4)
    s = modify(s, l, len(s) - 1, base)
    return s
    # if (s[-1] == '1'):
    #     s = s[:-1]
    #     s = erase_trailing_zero(s, base)
    #     s = s + '1'
    #     if (s[:-2] == '0'):
    #         return modify(s, len(s) - 3, len(s) - 1, base)
    #     else:
    #         return modify(s, len(s) - 2, len(s) - 1, base)
    # else:
    #     s = erase_trailing_zero(s, base)
    #     return modify(s, len(s) - 2, len(s) - 1, base)

def cleanup(s: str, base: int):

    for i in range(1, len(s)):
        if (s[i] == '0'):
            s = modify(s, i - 1, i, base)
    for i in range(len(s) - 1, 0, -1):
        s = modify(s, i - 1, i, base)
    s = erase_trailing_zero(s, base)
    return s

def solve() -> None:
    ans.clear()
    s = input()
    t = input()

    # 1) remove all leading 0's
    s_lz = count_leading_zero(s)
    t_lz = count_leading_zero(t)
    if (s_lz < t_lz):
        print(-1)
        return
    s = modify(s, 0, s_lz - t_lz)
    base = count_leading_zero(s)
    s, t = s[base:], t[base:]
    # print("1st: ", s, t)


    # 2) check if s == 1 or t == 1
    if (len(s) == 1 or len(t) == 1):
        if (s != t):
            print(-1)
        else:
            print(len(ans))
            for (l, r) in ans:
                print(l, r)
        return
    # print("2nd: ", s, t)

    assert (len(s) >= 2)
    # 至多操作两次长度即为3
    if (len(s) == 2): s = modify(s, 0, 1, base)
    if (len(s) == 2): s = modify(s, 0, 1, base)
    assert (len(s) >= 3)

    # 3) expand s to length(t)
    while (len(t) > 2):
        assert(len(s) >= 3)
        # 保证第2位是1且长度至少为4
        if (len(s) == 3): s = modify(s, 0, 2, base)
        if (s[1] == '0'): s = modify(s, 0, 1, base)
        
        if (s[-1] != t[-1]):
            s = change_last_digit(s, base)
        s, t = s[:-1], t[:-1]

        s = erase_trailing_zero(s, base)

        # print("3rd in progress: ", s, t)    
    
    # print("3rd: ", s, t)

    # 4) cleanup
    s = cleanup(s, base)

    # print("4th: ", s, t)

    # 5) check if s != t
    if (t == '11'):
        s = modify(s, 0, 1, base)

    # if (len(s) > 512): assert(0)

    print(len(ans))
    for (l, r, debug) in ans:
        print(l, r)
        # print(debug)
    

def main():
    t = int(input())
    for _ in range(t): solve()

if (__name__ == "__main__"):
    main()

详细

Test #1:

score: 100
Accepted
time: 5ms
memory: 10640kb

input:

3
1
111
110110
1101010
1111
111111

output:

-1
7
2 4
1 3
2 3
2 3
1 2
2 5
1 2
12
1 3
1 3
2 4
3 4
1 3
2 4
3 4
2 3
2 3
1 2
2 5
1 2

result:

ok Haitang Suki (3 test cases)

Test #2:

score: 0
Accepted
time: 14ms
memory: 10548kb

input:

1000
11100
111
1
11110
10001
10
1011
1111
10
1110
1100
11
11010
11
110
11
1
10001
10110
10
10
11111
10000
1001
10
1
11
10111
11
10
1
100
11
10100
1
10
101
11
1100
110
11
1110
1
1001
1
11111
10
10010
10
11001
110
1010
10011
1110
10100
1001
1001
101
100
1
1001
11
101
11
101
1001
1
1
1011
1
10
10
1011
...

output:

8
3 5
4 5
3 4
3 4
2 3
1 2
2 7
1 2
-1
8
1 2
2 3
3 4
4 5
3 4
2 3
1 2
2 9
7
1 2
1 3
2 3
2 3
1 2
2 5
1 2
10
1 2
1 2
1 3
1 2
2 4
2 3
2 3
1 2
2 5
1 2
7
2 3
3 4
3 4
2 3
1 2
2 7
1 2
8
2 3
4 5
4 5
3 4
2 3
1 2
2 9
1 2
5
2 3
2 3
1 2
2 5
1 2
-1
7
1 2
4 5
4 5
3 4
2 3
1 2
2 9
15
1 2
1 2
1 3
1 2
1 3
2 4
3 4
1 3
2 ...

result:

ok Haitang Suki (1000 test cases)

Test #3:

score: 0
Accepted
time: 19ms
memory: 10464kb

input:

1000
1110
110
1
11
1110
110
101
111
100
1001
10
110
1001
10011
10
11010
100
111
1101
1001
1
111
1
1
11
1
1011
1101
1
11
111
10
100
1110
1001
10
10
11
1
10
11
11
111
1100
10100
11001
10
110
1001
101
1
10011
100
10
10110
111
1100
110
11010
11
1000
1101
1010
1
1100
100
11010
1
1011
1
11001
1110
11
1110...

output:

4
2 3
1 2
2 5
1 2
-1
4
2 3
1 2
2 5
1 2
7
1 3
1 2
3 4
2 3
1 2
2 5
1 2
7
1 3
1 2
1 3
2 3
2 3
1 2
2 5
11
1 2
1 2
1 3
1 2
2 4
2 3
3 4
2 3
1 2
2 7
1 2
9
1 2
1 3
2 4
3 4
1 3
2 3
2 3
1 2
2 5
11
1 2
1 2
1 3
1 2
2 4
1 3
2 3
2 3
1 2
2 5
1 2
7
1 3
1 2
2 3
2 3
1 2
2 5
1 2
5
1 3
2 3
2 3
1 2
2 5
-1
0
-1
9
1 2
1 3...

result:

ok Haitang Suki (1000 test cases)

Test #4:

score: 0
Accepted
time: 26ms
memory: 10644kb

input:

1000
11110010
11110001
11010110
1001
11011110
1001110
111101100
111111100
110
101111001
10000100
10
1100100
101010
100
1000
1011110
110101
1001
10001111
100011111
1001111011
1110100
1010
1001100001
1000
11
101101
1000001111
11100
101001101
1
11
111001111
100101101
10
1
10111
1111000111
1101
10111
11...

output:

9
7 8
4 7
5 6
5 6
3 4
2 3
1 2
2 7
1 2
12
7 8
6 7
2 3
4 5
6 7
6 7
5 6
4 5
3 4
2 3
1 2
2 13
6
2 4
2 3
3 4
2 3
1 2
2 7
7
4 5
1 3
2 3
2 3
1 2
2 5
1 2
21
1 3
2 4
3 4
1 3
1 3
1 3
2 4
3 4
1 3
2 4
3 4
1 3
2 4
3 4
1 3
2 4
3 4
2 3
2 3
1 2
2 5
14
1 2
2 3
3 4
4 5
6 7
7 8
7 8
6 7
5 6
4 5
3 4
2 3
1 2
2 15
7
5 6
2...

result:

ok Haitang Suki (1000 test cases)

Test #5:

score: 0
Accepted
time: 22ms
memory: 10464kb

input:

1000
11
10
1111101
10
1011010001
1101010100
101110
101101001
110
110
100001
1111
10
1001100
1101101000
1
1
1110
11
1110000
110111010
1001000
110100000
1
1110101001
10
11111
1001101
110
1110
111
11
11000
1
111111
1
101111111
1100100100
101101100
1111110
10001
1001
1100110100
100
1001
101001
100011000...

output:

6
1 2
1 2
2 3
2 3
1 2
2 5
8
5 6
6 7
5 6
4 5
3 4
2 3
1 2
2 13
20
1 2
6 10
8 11
10 11
9 10
9 10
8 9
8 9
6 8
4 5
6 7
7 8
6 7
5 6
4 5
3 4
2 3
1 2
2 15
1 2
12
1 2
5 6
4 5
1 3
2 4
1 3
2 4
3 4
2 3
2 3
1 2
2 5
6
1 3
2 3
2 3
1 2
2 5
1 2
10
1 2
3 5
1 3
2 4
3 4
2 3
2 3
1 2
2 5
1 2
14
1 2
1 2
1 3
1 2
2 4
2 4
1 ...

result:

ok Haitang Suki (1000 test cases)

Test #6:

score: 0
Accepted
time: 25ms
memory: 10648kb

input:

1000
1010100001
1101101111
1000001111
1100000010
1101001000
1111011000
1011010000
1101111100
1000011000
1001010110
1100010110
1001001000
1000111110
1101100000
1101011010
1111000101
1110111001
1000000010
1111110000
1001100000
1000010111
1010101110
1110101000
1111100001
1110110101
1011100001
110111101...

output:

15
1 2
6 9
5 6
3 4
1 3
2 4
1 3
2 4
3 4
1 3
2 3
2 3
1 2
2 5
1 2
15
1 2
9 10
9 10
8 9
7 8
2 7
5 6
6 7
5 6
4 5
3 4
2 3
1 2
2 13
1 2
10
8 9
4 7
6 7
4 5
4 5
2 3
2 3
1 2
2 5
1 2
13
1 2
7 9
4 5
1 3
1 3
2 4
3 4
1 3
2 3
2 3
1 2
2 5
1 2
10
1 2
8 9
7 8
2 6
5 6
1 3
2 3
2 3
1 2
2 5
8
8 9
2 6
5 6
2 3
3 4
2 3
1 2
...

result:

ok Haitang Suki (1000 test cases)

Test #7:

score: 0
Accepted
time: 37ms
memory: 10552kb

input:

1000
1010010100
1100011110
1111100001
1110100100
1001011000
1001011110
1110100101
1000001010
1110010010
1110110010
1010001000
1110011110
1010101110
1100011011
1000000100
1100100001
1010001011
1111101100
1001110101
1010001011
1001001010
1010010111
1011001010
1110001111
1000001000
1111001011
100111101...

output:

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

result:

ok Haitang Suki (1000 test cases)

Test #8:

score: -100
Wrong Answer
time: 80ms
memory: 10608kb

input:

1000
10001101010010010010011111000100011110010111010011100110011
101100010110011111000010101
101111101000100010010101
10100101000010100001101000001101010111
1101110100111100111110101101101000110101010010011100
1110100100101011000011
1100001100101011010000111010111000000101
11101000100000101000001111...

output:

77
1 2
55 58
57 58
56 57
56 57
55 56
54 55
52 53
51 52
47 48
44 46
44 45
43 44
43 44
42 43
40 42
40 41
2 3
3 4
6 7
8 9
10 11
11 12
13 14
14 15
16 17
17 18
19 20
20 21
26 27
27 28
28 29
30 31
31 32
32 33
37 38
38 39
39 40
38 39
37 38
36 37
35 36
34 35
33 34
32 33
31 32
30 31
29 30
28 29
27 28
26 27
2...

result:

wrong answer too long (test case 831)