Submission #915571

#TimeUsernameProblemLanguageResultExecution timeMemory
915571josanneo22Type Printer (IOI08_printer)C++17
100 / 100
95 ms84820 KiB
#include<bits/stdc++.h> #include <random> using namespace std; namespace NEO{ std::mt19937 cincai(std::chrono::steady_clock::now().time_since_epoch().count()); using i64 = long long; #define pb push_back #define mp make_pair #define cs constexpr #define L(i,j,k) for(int i=(j);i<=(k);++i) #define R(i,j,k) for(int i=(j);i>=(k);--i) #define all(x) x.begin(),x.end() #define me(x,a) memset(x,a,sizeof(x)) //~ #ifndef ONLINE_JUDGE //~ #include "debug.h" //~ #else //~ #define dbg(...) 43 //~ #endif }using namespace NEO; struct node{ int nxt[26]; bool is_longest, finish_word; node(){ me(nxt, 0); is_longest = false; finish_word = false; } }; cs int _N = 25000 * 30; int tot = 0; node trie[_N]; void build(string S){ int M = S.size(), P = 0; for(int i = 0; i < M; i++){ int nw = S[i] - 'a'; if(trie[P].nxt[nw] == 0){ trie[P].nxt[nw] = ++tot; trie[tot] = node(); } P = trie[P].nxt[nw]; } trie[P].finish_word = true; } void paint(string S){ int P = 0; for(int i = 0; i < (int)S.size(); i++){ int nw = S[i] - 'a'; P = trie[P].nxt[nw]; trie[P].is_longest = true; } } string ans = ""; void dfs(int P){ int longest = -1; if(trie[P].finish_word) ans += 'P'; for(int i = 0; i < 26; i++){ int next_node = trie[P].nxt[i]; if(trie[next_node].is_longest) longest = i; else if(next_node != 0) { ans += (i + 'a'); dfs(next_node); } } if(longest != -1){ ans += (longest + 'a'); dfs(trie[P].nxt[longest]); } else if(longest == -1 && trie[P].is_longest) return; else ans += '-'; } int main() { ios::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr); int N; cin >> N; vector<string> s(N + 1); L(i, 1, N) cin >> s[i]; string longest = ""; L(i, 1, N) { build(s[i]); if(longest.size() < s[i].size()) longest = s[i]; } paint(longest); dfs(0); cout << ans.size() << '\n'; for(auto & c : ans) cout << c << '\n'; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...