Submission #674027

#TimeUsernameProblemLanguageResultExecution timeMemory
674027peacebringer1667Type Printer (IOI08_printer)C++17
0 / 100
1100 ms16724 KiB
#pragma GCC optimize("O2") #include<bits/stdc++.h> #define whilst while typedef long long ll; using namespace std; string a[25003]; int f[650078][27]; int b[25003]; int m = 0;bool eow[650078]; vector <vector<int>> vec(650078); void dfs(int u){ cout << (char)f[u][0] << endl; if (eow[u]) cout << "P" << endl; for (int i = 0 ; i < vec[u].size() ; i++) dfs(vec[u][i]); cout << "-" << endl; } int main(){ ios_base::sync_with_stdio(false); cin.tie(0);cout.tie(0); int d1 = 0,n,cur,j,maxlen = 0,index = n;string x;char t; cin >> n; for (int i = 1 ; i <= n ; i++){ cin >> a[i]; if (maxlen < a[i].size()){ maxlen = a[i].size();index = i; } } swap(a[index],a[n]);t = a[n][0]; for (int i = 1 ; i < n; i++) if (a[i][0] != a[n][0]){ cur = 0,j = 0; while (j < a[i].size() && f[cur][a[i][j]-96]){ cur = f[cur][a[i][j]-96];j++; } if (j == a[i].size()){ j = 0; while (j < a[i].size()-1) cur = f[cur][a[i][j]-96];j++; eow[cur] = 1; } for (int k = j ; k < a[i].size() ; k++){ m++;f[cur][a[i][k]-96] = m;f[m][0] = a[i][k];vec[cur].push_back(m); cur = m; } eow[m] = 1; } for (int i = 1 ; i <= n ; i++) if (a[i][0] == t){ cur = 0,j = 0; while (j < a[i].size() && f[cur][a[i][j]-96]){ cur = f[cur][a[i][j]-96];j++; } if (j == a[i].size()){ j = 0; while (j < a[i].size()-1) cur = f[cur][a[i][j]-96];j++; eow[cur] = 1; } for (int k = j ; k < a[i].size() ; k++){ m++;f[cur][a[i][k]-96] = m;f[m][0] = a[i][k];vec[cur].push_back(m); cur = m; } eow[m] = 1; } cout << 2*m - a[n].size() + n<< endl; for (int i = 0 ; i < vec[0].size()-1 ; i++) dfs(vec[0][i]); return 0; }

Compilation message (stderr)

printer.cpp: In function 'void dfs(int)':
printer.cpp:14:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   14 |  for (int i = 0 ; i < vec[u].size() ; i++)
      |                   ~~^~~~~~~~~~~~~~~
printer.cpp: In function 'int main()':
printer.cpp:25:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   25 |      if (maxlen < a[i].size()){
      |          ~~~~~~~^~~~~~~~~~~~~
printer.cpp:33:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   33 |         while (j < a[i].size() && f[cur][a[i][j]-96]){
      |                ~~^~~~~~~~~~~~~
printer.cpp:36:9: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   36 |   if (j == a[i].size()){
      |       ~~^~~~~~~~~~~~~~
printer.cpp:38:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   38 |    while (j < a[i].size()-1)
      |           ~~^~~~~~~~~~~~~~~
printer.cpp:38:4: warning: this 'while' clause does not guard... [-Wmisleading-indentation]
   38 |    while (j < a[i].size()-1)
      |    ^~~~~
printer.cpp:39:31: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'while'
   39 |      cur = f[cur][a[i][j]-96];j++;
      |                               ^
printer.cpp:42:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   42 |   for (int k = j ; k < a[i].size() ; k++){
      |                    ~~^~~~~~~~~~~~~
printer.cpp:50:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   50 |         while (j < a[i].size() && f[cur][a[i][j]-96]){
      |                ~~^~~~~~~~~~~~~
printer.cpp:53:9: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   53 |   if (j == a[i].size()){
      |       ~~^~~~~~~~~~~~~~
printer.cpp:55:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   55 |    while (j < a[i].size()-1)
      |           ~~^~~~~~~~~~~~~~~
printer.cpp:55:4: warning: this 'while' clause does not guard... [-Wmisleading-indentation]
   55 |    while (j < a[i].size()-1)
      |    ^~~~~
printer.cpp:56:31: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'while'
   56 |      cur = f[cur][a[i][j]-96];j++;
      |                               ^
printer.cpp:59:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   59 |   for (int k = j ; k < a[i].size() ; k++){
      |                    ~~^~~~~~~~~~~~~
printer.cpp:66:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   66 |  for (int i = 0 ; i < vec[0].size()-1 ; i++) dfs(vec[0][i]);
      |                   ~~^~~~~~~~~~~~~~~~~
printer.cpp:21:9: warning: unused variable 'd1' [-Wunused-variable]
   21 |     int d1 = 0,n,cur,j,maxlen = 0,index = n;string x;char t;
      |         ^~
#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...