Submission #830391

#TimeUsernameProblemLanguageResultExecution timeMemory
830391petezaHomework (CEOI22_homework)C++14
53 / 100
133 ms46824 KiB
#include <bits/stdc++.h>
using namespace std;

string str;
int bin[1000005][2];
int type[1000005], sz[1000005];
int cnode = 0;
stack<int> stk;

int ci = 0;

pair<int, int> dfs(int x) {
    if(type[x] == 2) return {1, 1};
    queue<int> q; q.emplace(x);
    vector<int> dfss;
    while(!q.empty()) {
        if(type[q.front()] == type[x]) {
            q.push(bin[q.front()][0]);
            q.push(bin[q.front()][1]);
        } else dfss.push_back(q.front());
        q.pop();
    }
    int l, r;
    if(type[x] == 0) {
        l = INT_MAX; r = 0;
        for(int e:dfss) {
            pair<int, int> res = dfs(e);
            l = min(res.first, l);
            r += sz[e]-res.second+1;
        }        
        r = sz[x] - r + 1;
    } else {
        l = 0; r = INT_MAX;
        for(int e:dfss) {
            pair<int, int> res = dfs(e);
            l += res.first;
            r = min(sz[e]-res.second, r);
        }
        r = sz[x] - r;
    }
    //cout << x << " -> " << l << ' ' << r << '\n';
    return {l, r};
}


int main() {
    cin >> str; 
    for(int i=0;i<str.size();) {
        if(str[i] == ',' || str[i]=='('){i++; continue;}
        if(str[i] == 'm') {
            stk.push(cnode);
            if(str[i+1] == 'i') { //minimum
                type[cnode++] = 0;
            } else {
                type[cnode++] = 1;
            }
            i += 4;
        } else if(str[i] == '?') {
            stk.push(cnode); sz[cnode] = 1;
            type[cnode++] = 2;
            i++;
        } else {
            int e1 = stk.top(); stk.pop();
            int e2 = stk.top(); stk.pop();
            bin[stk.top()][0] = e2; bin[stk.top()][1] = e1;
            sz[stk.top()] = sz[e1] + sz[e2];
            i++;
        }
    }
    pair<int, int> res = dfs(0);
    cout << res.second - res.first + 1;
}

// min(max(max(?,?),max(?,?)),min(max(?,?),max(?,?)))

Compilation message (stderr)

Main.cpp: In function 'int main()':
Main.cpp:48:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   48 |     for(int i=0;i<str.size();) {
      |                 ~^~~~~~~~~~~
#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...