Untitled

mail@pastecode.io avatar
unknown
c_cpp
a year ago
2.0 kB
2
Indexable
Never
//Please do not modify the header files.

#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;


class Stack{
    private: 
        vector<int> arr;
    
    public:
        Stack(int s) {
            arr.resize(s);
        };

        bool empty(){
            return (arr.size() == 0);
        }

        void push(int x){
            arr.push_back(x);
        }

        int top(){
            return arr.back();
        }

        void pop(){
            arr.pop_back();
        }

        int size() {
            return arr.size();
        }

        void stackify(){
            reverse(arr.begin(), arr.end());
        }

};


int main() {
    /* Enter your code here. Read input from STDIN. Print output to STDOUT */   
    
    int n1, n2, n3;
    cin >> n1 >> n2 >> n3;

    Stack s1(n1);
    Stack s2(n2);
    Stack s3(n3);

    int tmp;
    int sum1 = 0, sum2 = 0, sum3 = 0;
    while (n1--){
        cin >> tmp;
        s1.push(tmp);
        sum1 += tmp;
    }
    s1.stackify();
    while (n2--){
        cin >> tmp;
        s2.push(tmp);
        sum2 += tmp;
    }
    s2.stackify();
    while (n3--){
        cin >> tmp;
        s3.push(tmp);
        sum3 += tmp;
    }
    s3.stackify();

    while (!s1.empty() || s2.empty() || s3.empty()){
        if ((sum1 > sum2 && sum1 >= sum3) || (sum1 >= sum2 && sum1 > sum3)){
            sum1 -= s1.top();
            s1.pop();
        }
        else if ((sum2 > sum3 && sum2 >= sum1) || (sum2 >= sum3 && sum2 > sum1)){
            sum2 -= s2.top();
            s2.pop();
        }
        else if ((sum3 > sum1 && sum3 >= sum2) || (sum3 >= sum1 && sum3 > sum2)){
            sum3 -= s3.top();
            s3.pop();
        }
        
        if (sum1 == sum2 && sum1 == sum3){
            cout << sum1;
            return 0;
        }
    }

    cout << 0;
    return 0;
}