summaryrefslogtreecommitdiff
path: root/2022/Cpp/Day7/main.cpp
blob: 893691c9defa1dd8451d15a405569883c9c3760e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#include<bits/stdc++.h>

using namespace std;

//pretty printing
template<typename K, typename V>
void printm(const map<K, V> &mp) {
  cerr << "{" << endl;
  for (auto p : mp) {
    cerr << "  { " << p.first << " : " << p.second << " }\n";
  }
  cerr << "}" << endl;
}
template<typename T>
void printv(const vector<T> &v) {
  cerr << "[";
  for (int i = 0; i < v.size(); i++) {
    if (i == v.size() - 1) {
      cerr << v[i];
    } else {
      cerr << v[i] << ", ";
    }
  }
  cerr << "]\n";
}

template<typename T>
void printvv(const vector<vector<T>> &v) {
  cerr << "[\n";
  for (auto &vec : v) {
    cout << "  ";
    printv(vec);
  }
  cerr << "]\n";
}
void print() {
  cerr << "\n";
}

template<typename T, typename... TS>
void print(T val, TS... vals) {
  cerr << val << " ";
  print(vals...);
}

bool isDir(string &s) {
  return s[0] == 'd';
}

bool isFile(string &s) {
  return s[0] >= '0' && s[0] <= '9';
}

long long sumDir(string fileName, map<string, vector<string>> &dirContent) {
  if (isFile(fileName)) {
    int firstSpace = fileName.find(' ');
    cout << fileName.substr(0, firstSpace) << '\n';
    return stoi(fileName.substr(0, firstSpace));
  } else {
    long long sum = 0;
    for (auto subfile : dirContent[fileName]) {
      // cout << subfile << '\n';
      if (isFile(subfile)) {
        sum += sumDir(subfile, dirContent);
      } else {
        sum += sumDir(subfile, dirContent);
      }
    }
    return sum;
  }
}
 
int main() {
  string s;
  vector<string> dirs;
  map<string, long long> mp;
  map<string, vector<string>> dirContent;
  string cwd = "/";
  vector<string> lines;
 
  while(getline(cin, s)) {
    lines.push_back(s);
  }
 
  for (int i = 0; i < lines.size(); i++) {
    s = lines[i];
    if (s[0] == '$') {
      // it's a command
      if (s[2] == 'l') {
        // ls command
        string prevline = lines[i - 1];
        string tmp = prevline.substr(prevline.find(' ', 2) + 1);
        cwd = tmp;
        // cout << cwd << '\n';
      } 
    } else {
      // it's a file or a dir
      string prevline = lines[i - 1];
      if (isDir(s)) {
        string tmp = s.substr(s.find(' ') + 1);
        dirContent[cwd].push_back(tmp);
      } else if (isFile(s)) {
        dirContent[cwd].push_back(s);
        // cout << "file size: " << fsize << '\n';
        // mp[cwd] += fsize;
      }
    } 
  }

  long long ans = 0;
  for (auto [dir, ls] : dirContent) {
    cout << "cwd: " << dir << '\n';
    cout << "\t\t";
    printv(ls);
    // long long sum = sumDir(dir, dirContent);
    // if (sum <= 100000) {
    //   ans += sum;
    // }
  }
  cout << ans << '\n';
}