QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#121602#4273. Good Gamebashkort#0 0ms3528kbC++201.0kb2023-07-08 15:24:002024-07-04 00:31:09

Judging History

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

  • [2024-07-04 00:31:09]
  • 评测
  • 测评结果:0
  • 用时:0ms
  • 内存:3528kb
  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-07-08 15:24:00]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;
using ll = long long;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int n;
    cin >> n;

    string s;
    cin >> s;

    vector<pair<int, int>> ans;

    while (size(s) > 1) {
        for (int i = 1; i < size(s); ++i) {
            if (s[i] == s[i - 1]) {
                int j = i;
                while (j < size(s) && s[i] == s[j]) {
                    j += 1;
                }
                int len = j - (i - 1);
                while (len > 3) {
                    ans.push_back({i, 2});
                    len -= 2;
                }
                ans.push_back({i, len});
                s.erase(s.begin() + i - 1, s.begin() + j);
                break;
            }
        }
    }

    if (!s.empty()) {
        cout << -1 << '\n';
        return 0;
    }

    cout << size(ans) << '\n';

    for (auto [l, r] : ans) {
        cout << l << " " << r << '\n';
    }

    return 0;
}

详细

Subtask #1:

score: 0
Time Limit Exceeded

Test #1:

score: 3
Accepted
time: 0ms
memory: 3528kb

input:

9
ABAABBBAA

output:

4
3 2
2 2
2 2
1 3

result:

ok good solution!

Test #2:

score: 0
Time Limit Exceeded

input:

13
ABABBABABBABA

output:


result:


Subtask #2:

score: 0
Time Limit Exceeded

Test #51:

score: 0
Time Limit Exceeded

input:

299
ABABABABABABABABABABABABABABABABABBAABBAABBAABBAAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBAABBBAABBAABBAABBAABBAABBAABBAABBAABBABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABA...

output:


result:


Subtask #3:

score: 0
Time Limit Exceeded

Test #102:

score: 0
Time Limit Exceeded

input:

5998
BABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABAB...

output:


result:


Subtask #4:

score: 0
Time Limit Exceeded

Test #153:

score: 0
Time Limit Exceeded

input:

999997
ABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABABA...

output:


result: