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
#include<bits/stdc++.h>

using namespace std;

vector<pair<int, int>> przedzialy;

int main()
{
	ios_base::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);

    bool dalej = 0;
    int c1, c2, cs, start;
    long long wynik = 0, obok = 1;
    string skl1, skl2, suma;
    cin >> skl1 >> skl2 >> suma;
    for(int i = suma.size() - 1; i >= 0; i--)
    {
        c1 = skl1[i] - '0';
        c2 = skl2[i] - '0';
        cs = suma[i] - '0';
        if(dalej)
        {
            if(c1 + c2 + 1 == cs)
            {
                przedzialy.push_back({start, i});
                dalej = 0;
                continue;
            }
            if((c1 + c2 + 1 >= 10) && ((c1 + c2 + 1) % 10 == cs))
            {
                continue;
            }
        }
        dalej = 0;
        if(c1 + c2 == cs)
        {
            przedzialy.push_back({i, i});
            continue;
        }
        if((c1 + c2 >= 10) && ((c1 + c2) % 10 == cs))
        {
            dalej = 1;
            start = i;
        }
    }
    if(!przedzialy.size())
    {
        cout << 0;
        return 0;
    }
    for(int i = 1; i < przedzialy.size(); i++)
    {
        if(przedzialy[i - 1].second - 1 == przedzialy[i].first)
        {
            obok++;
            continue;
        }
        wynik += (obok * (obok + 1)) / 2;
        obok = 1;
    }
    cout << wynik + (obok * (obok + 1)) / 2;
	return 0;
}