# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
83383 | wjoao | Cezar (COCI16_cezar) | C++11 | 3 ms | 612 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
#define maxn 500
using namespace std;
string entrada[maxn], ordenado[maxn];
int n, ord[maxn], grau[maxn], atual = 'a', mark[maxn], impossivel;
char encryption[maxn];
vector<int> g[maxn];
void dfs(int v, int cor){
mark[v] = cor;
for(int i = 0; i < g[v].size(); i++){
int u = g[v][i];
if(mark[u] == cor){
impossivel = true;
return;
}else if(mark[u] == 0){
dfs(u, cor);
}
}
encryption[atual++]=v;
}
int main(){
cin >> n;
for(int i = 0; i < n; i++ ) cin >> entrada[i];
for(int i = 0; i < n; i++ ){
cin >> ord[i]; ord[i]--;
ordenado[i] = entrada[ord[i]];
}
for(int i = 1; i < n; i++){
int j = 0;
while( j < ordenado[i].size() &&
j < ordenado[i-1].size() &&
ordenado[i][j] == ordenado[i-1][j] ) j++;
if( j < ordenado[i].size() && j < ordenado[i-1].size()){
g[ordenado[i][j]].push_back(ordenado[i-1][j]);
}
}
for(int i = 'a'; i <= 'z'; i++){
if(mark[i] == 0) dfs(i, i);
}
if(impossivel){
cout << "NE" << endl;
}else{
cout << "DA" << endl;
for(int i = 'a'; i <= 'z'; i++){
cout << encryption[i];
}cout << endl;
}
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |