Submission #83381

#TimeUsernameProblemLanguageResultExecution timeMemory
83381luciocfCezar (COCI16_cezar)C++14
30 / 100
4 ms680 KiB
#include <bits/stdc++.h> using namespace std; const int maxs = 30; const int maxn = 110; typedef pair<int, string> pii; int grau[maxs], ans[maxs]; pii num[maxn]; vector<int> grafo[maxs]; string s[maxn]; int main(void) { int n; cin >> n; for (int i = 1; i <= n; i++) cin >> num[i].second; for (int i = 1; i <= n; i++) { int x; cin >> x; num[x].first = i; } sort(num+1, num+n+1); bool ok = 1; for (int i = 1; i <= n; i++) { for (int j = i+1; j <= n; j++) { string s1 = num[i].second, s2 = num[j].second; bool prefixo = 1; for (int k = 0; k < min(s1.size(), s2.size()); k++) { if (s1[k] == s2[k]) continue; grafo[s1[k]-'a'].push_back(s2[k]-'a'); grau[s2[k]-'a']++, prefixo = 0; break; } if (prefixo && s1.size() > s2.size()) ok = 0; } } if (!ok) { cout << "NE\n"; return 0; } queue<int> fila; for (int i = 0; i < 26; i++) if (!grau[i]) fila.push(i); int atual = 0; while (!fila.empty()) { int x = fila.front(); fila.pop(); ans[x] = atual++; for (auto v: grafo[x]) { grau[v]--; if (!grau[v]) fila.push(v); } } for (int i = 0; i < 26; i++) { if (grau[i]) { cout << "NE\n"; return 0; } } cout << "DA\n"; for (int i = 0; i < 26; i++) cout << (char) (ans[i]+'a'); cout << "\n"; }

Compilation message (stderr)

cezar.cpp: In function 'int main()':
cezar.cpp:45:22: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for (int k = 0; k < min(s1.size(), s2.size()); k++)
                    ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...