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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
#include <iostream>
#include <cstring>

using namespace std;

long long n , w=0 , x , z=0;
int kw=0 , f=0;
string a , b;

int main()
{
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cin >> n;
    cin >> a;
    for(long long i=0;i<n-1;i++)
    {
        f=1;
        kw=0;
        b=a;
        cin >> a;
        if(a.size()<b.size()+z || (a.size()==b.size()+z && a<=b))
        {
            for(int j=0;j<max(b.size(),a.size());j++)
            {
                if(j>=b.size())
                {
                    if(j>=a.size())
                    {
                        if('0'!='9') f=1;
                        else f=0;
                    }
                    else if(a[j]>0 && kw==0)
                    {
                        kw=1;
                    }
                    else if(a[j]<0 && kw==0)
                    {
                        kw=2;
                    }
                }
                else if(a[j]!=b[j])
                {
                    if(j>=a.size())
                    {
                        if(b[j]!='9') f=1;
                        else f=0;
                    }
                    else if(a[j]>b[j] && kw==0)
                    {
                        kw=1;
                    }
                    else if(a[j]<b[j] && kw==0)
                    {
                        kw=2;
                    }
                }
            }
            if(a.size()==b.size()+z)
            {
                a=a+'0';
                w++;
            }
            else if(kw==1)
            {
                if(b.size()+z<20)
                {
                    for(int j=a.size();j<b.size();j++)
                    {
                        a=a+'0';
                        w++;
                    }
                }
                else
                {
                    z=z+b.size()-a.size();
                    w=w+z;
                }
            }
            else if(kw==2)
            {
                if(b.size()+z<20)
                {
                    for(int j=a.size();j<b.size()+1;j++)
                    {
                        a=a+'0';
                        w++;
                    }
                }
                else
                {
                    z=z+b.size()-a.size()+1;
                    w=w+z;
                }
            }
            else if(kw==0 && f==0)
            {
                if(b.size()+z<20)
                {
                    for(int j=a.size();j<b.size()+1;j++)
                    {
                        a=a+'0';
                        w++;
                    }
                }
                else
                {
                    z=z+b.size()-a.size()+1;
                    w=w+z;
                }
            }
            else if(kw==0 && f==1)
            {
                if(b.size()+z<20)
                {
                    w=w+b.size()-a.size();
                    a=b;
                    for(int j=a.size()-1;j>=0;j--)
                    {
                        if(a[j]=='0')
                        {
                            a[j]='1';
                            break;
                        }
                        else if(a[j]=='1')
                        {
                            a[j]='2';
                            break;
                        }
                        else if(a[j]=='2')
                        {
                            a[j]='3';
                            break;
                        }
                        else if(a[j]=='3')
                        {
                            a[j]='4';
                            break;
                        }
                        else if(a[j]=='4')
                        {
                            a[j]='5';
                            break;
                        }
                        else if(a[j]=='5')
                        {
                            a[j]='6';
                            break;
                        }
                        else if(a[j]=='6')
                        {
                            a[j]='7';
                            break;
                        }
                        else if(a[j]=='7')
                        {
                            a[j]='8';
                            break;
                        }
                        else if(a[j]=='8')
                        {
                            a[j]='9';
                            break;
                        }
                        else if(a[j]=='9')
                        {
                            a[j]='0';
                        }
                    }
                }
                else
                {
                    z=z+b.size()-a.size();
                    w=w+z;
                }
            }
        }
    }
    cout << w;
    return 0;
}