Submission details
Task:ModAdd
Sender:hugues
Submission time:2016-09-24 13:56:22 +0300
Language:C++
Status:READY
Result:
Test results
testverdicttime
#10.05 sdetails
#20.06 sdetails
#30.06 sdetails
#40.06 sdetails
#50.05 sdetails
#60.06 sdetails
#70.06 sdetails
#80.06 sdetails
#90.05 sdetails
#100.06 sdetails

Code

using namespace std;
#include <bits/stdc++.h>

#define sz(x) ((int)x.size())
#define sqr(x) ((x)*(x))
#define pb push_back
#define clr clear()
#define inf (1<<30)
#define eps 1e-9
typedef long long i64;
typedef unsigned long long ui64;
#include <math.h>



int main() {
    ios_base::sync_with_stdio(0);

    int a, b;
    cin >> a >> b;
    int nb_digit_a = floor((float)(log10(a))) + 1;
    int nb_digit_b = floor((float)(log10(b))) + 1;

    vector<int> va;
    for(int i = 0; i < nb_digit_a; i++){
        va.push_back(int(a / pow(10, i)) % 10);
    }

    vector<int> vb;
    for(int i = 0; i < nb_digit_b; i++){
        vb.push_back(int(b / pow(10, i)) % 10);
    }

    int max_digit = max(nb_digit_a, nb_digit_b);

    int res = 0;
    for(int i = 0; i < max_digit; i++){
        if(i < nb_digit_a && i < nb_digit_b){
            res += (va[i] + vb[i]) % 10 * pow(10, i);
        }else if(i >= nb_digit_b && i < nb_digit_a){
            res += (va[i]) % 10 * pow(10, i);
        }else {
            res += (vb[i]) % 10 * pow(10, i);
        }
    }

    cout << res << endl;

    return 0;
}

Test details

Test 1

Verdict:

input
3797629225
9766508989

correct output
2453127104

user output
2147483643

Test 2

Verdict:

input
552139016901047883384892240490...

correct output
552139016901047883384892240490...

user output
2147483643

Test 3

Verdict:

input
860793811134668093345482099582...

correct output
487710306894083216377653715430...

user output
2147483643

Test 4

Verdict:

input
2
870841652294197226626825161089...

correct output
870841652294197226626825161089...

user output
-2147483648

Test 5

Verdict:

input
0
404905566051213252279994991040...

correct output
404905566051213252279994991040...

user output
2147483647

Test 6

Verdict:

input
430112167406460960088878635088...

correct output
430112167406460960088878635088...

user output
2147483643

Test 7

Verdict:

input
867016005819001635643395991596...

correct output
999999999999999999999999999999...

user output
2147483643

Test 8

Verdict:

input
120453771521975552204976752778...

correct output
0

user output
2147483643

Test 9

Verdict:

input
239979749009277805816504910098...

correct output
239979749009277805816504910098...

user output
2147483643

Test 10

Verdict:

input
990963963634143754324162574923...

correct output
818540385713473048971388312665...

user output
2147483643