Submission #83383

# Submission time Handle Problem Language Result Execution time Memory
83383 2018-11-07T13:15:25 Z wjoao Cezar (COCI16_cezar) C++11
0 / 100
3 ms 612 KB
#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

cezar.cpp: In function 'void dfs(int, int)':
cezar.cpp:14:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int i = 0; i < g[v].size(); i++){
                  ~~^~~~~~~~~~~~~
cezar.cpp: In function 'int main()':
cezar.cpp:37:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     while(  j < ordenado[i].size() && 
             ~~^~~~~~~~~~~~~~~~~~~~
cezar.cpp:38:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             j < ordenado[i-1].size() && 
             ~~^~~~~~~~~~~~~~~~~~~~~~
cezar.cpp:41:11: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     if( j < ordenado[i].size() && j < ordenado[i-1].size()){
         ~~^~~~~~~~~~~~~~~~~~~~
cezar.cpp:41:37: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     if( j < ordenado[i].size() && j < ordenado[i-1].size()){
                                   ~~^~~~~~~~~~~~~~~~~~~~~~
cezar.cpp:42:23: warning: array subscript has type 'char' [-Wchar-subscripts]
       g[ordenado[i][j]].push_back(ordenado[i-1][j]);
                       ^
# Verdict Execution time Memory Grader output
1 Incorrect 2 ms 376 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 3 ms 380 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 424 KB Output is correct
2 Incorrect 2 ms 424 KB Output isn't correct
# Verdict Execution time Memory Grader output
1 Incorrect 2 ms 472 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 2 ms 544 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 588 KB Output is correct
2 Incorrect 2 ms 588 KB Output isn't correct
# Verdict Execution time Memory Grader output
1 Incorrect 2 ms 612 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 2 ms 612 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 2 ms 612 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 3 ms 612 KB Output isn't correct
2 Halted 0 ms 0 KB -