Advertisement
Guest User

Untitled

a guest
Feb 25th, 2018
70
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.84 KB | None | 0 0
  1. #include <iostream>
  2. #include <fstream>
  3. #include <vector>
  4. #include <algorithm>
  5. #include <unordered_map>
  6. #include <map>
  7. #include <string>
  8. #include <cmath>
  9. #include <deque>
  10. #include <cstring>
  11. #include <set>
  12.  
  13. using namespace std;
  14.  
  15. #define endl '\n'
  16.  
  17. struct node {
  18.     bool term;
  19.     map<char, node*> edg;
  20.     node() : term(false) {}
  21. };
  22.  
  23. int main () {
  24.     ios::sync_with_stdio(false);
  25.     cin.tie(0);
  26.  
  27.     node* root = new node;
  28.     node* place = root;
  29.     string s;
  30.     int ans = 0;
  31.     int lastmoreone = 0;
  32.     bool f;
  33.     int glub = 0;
  34.     while(getline(cin, s)) {
  35.         f = true;
  36.         for (int i = 0; i < s.size(); i++) {
  37.             if (!(s[i] >= 'a' && s[i] <= 'z')) {
  38.                 place = root;
  39.                 glub = 0;
  40.                 ans++;
  41.                 f = true;
  42.                 lastmoreone = 0;
  43.             }
  44.             else if (f) {
  45.                 if (place->edg.find(s[i]) == place->edg.end()) {
  46.                     f = false;
  47.                     ans++;
  48.                     place->edg[s[i]] = new node;
  49.                     place = place->edg[s[i]];
  50.                     if ((i + 1 == s.size()) || (i + 1 < s.size() && !(s[i + 1] >= 'a' && s[i + 1] <= 'z'))) {
  51.                         place->term = true;
  52.                     }
  53.                 }
  54.                 else {
  55.                     if (place->edg.size() > 1 || place->term) {
  56.                         lastmoreone = glub;
  57.                     }
  58.                     place = place->edg[s[i]];
  59.                     glub++;
  60.                     ans++;
  61.                     if (place->term && place->edg.size() == 0) {
  62.                         ans -= max(glub - lastmoreone - 2, 0);
  63.                         f = false;
  64.                     }
  65.                     if ((i + 1 == s.size()) || (i + 1 < s.size() && !(s[i + 1] >= 'a' && s[i + 1] <= 'z'))) {
  66.                         place->term = true;
  67.                     }
  68.                     //else if (place->term) {
  69.                     //  lastmoreone = glub;
  70.                     //}
  71.                 }
  72.             }
  73.             else {
  74.                 ans++;
  75.                 place->edg[s[i]] = new node;
  76.                 place = place->edg[s[i]];
  77.                 if ((i + 1 == s.size()) || (i + 1 < s.size() && !(s[i + 1] >= 'a' && s[i + 1] <= 'z'))) {
  78.                     place->term = true;
  79.                 }
  80.             }
  81.         }
  82.         place = root;
  83.         glub = 0;
  84.         f = true;
  85.         ans++;
  86.         lastmoreone = 0;
  87.         //cout << ans;
  88.     }
  89.     cout << ans;
  90. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement