답안 #1040953

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1040953 2024-08-01T12:46:46 Z ArthuroWich Type Printer (IOI08_printer) C++17
80 / 100
816 ms 93228 KB
#include <bits/stdc++.h>
using namespace std;
int trie[500005][26], le[500005][26], co = 1, en[250000];
vector<char> ans;
void insert(string s) {
    int n = 0;
    for (int i = 0; i < s.length(); i++) { 
        char c = s[i];
        le[n][c-'a'] = max(le[n][c-'a'], (int)s.length()-i);
        if (!trie[n][c-'a']) {
            trie[n][c-'a'] = co;
            co++;
        }
        n = trie[n][c-'a'];
    }
    en[n] = 1;
}
void dfs(int a) {
    if (en[a]) {
        ans.push_back('P');
    }
    vector<pair<int, int>> v;
    for (int i = 0; i < 26; i++) {
        if (trie[a][i]) {
            v.push_back({le[a][i], i});
        }
    }
    sort(v.begin(), v.end());
    for (auto [_, i] : v) {
        ans.push_back((char)(i+'a'));
        dfs(trie[a][i]);
        ans.push_back('-');
    }
}
void solve() {
    int n;
    cin >> n;   
    for (int i = 0; i < n; i++) {
        string s;
        cin >> s;
        insert(s);
    }
    dfs(0);
    while(!ans.empty() && ans.back() == '-') {
        ans.pop_back();
    }
    cout << ans.size() << endl;
    for (char c : ans) {
        cout << c << endl;
    }
}
int32_t main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    int t;
    t = 1;
    while(t--) {
        solve();
    }
}

Compilation message

printer.cpp: In function 'void insert(std::string)':
printer.cpp:7:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    7 |     for (int i = 0; i < s.length(); i++) {
      |                     ~~^~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Correct 1 ms 348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 1 ms 348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 348 KB Output is correct
2 Correct 13 ms 1256 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 20 ms 1884 KB Output is correct
2 Correct 17 ms 2140 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 53 ms 5720 KB Output is correct
2 Correct 111 ms 11868 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 116 ms 14036 KB Output is correct
2 Correct 34 ms 3160 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 301 ms 34756 KB Output is correct
2 Incorrect 665 ms 78540 KB printed invalid word
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 266 ms 27084 KB Output is correct
2 Incorrect 816 ms 93228 KB printed invalid word
3 Halted 0 ms 0 KB -