#include <iostream>
#include <string>
#include <vector>
using namespace std;
string increment(string in){
for(int i=in.size()-1; i>=0; i--){
if(in[i]=='9'){
in[i]='0';
}
else{
in[i] += 1;
return in;
}
}
in = '1' + in;
return in;
}
int main(){
int n;
cin>>n;
vector <string> seq;
string a;
cin>>a; n--;
long long counter =0;
while(n){
n--;
string b;
cin >> b;
string c = increment(a);
if(a.size()<b.size()) a = b;
else if(b.size()<=c.size() && c.substr(0, b.size())==b){
counter += (c.size()-b.size());
a = c;
}
else {
int len = a.size()-b.size();
while(len){
len--;
b += '0';
counter ++;
}
if(a<b) a=b;
else{
b += '0';
counter ++;
a=b;
}
}
}
cout<<counter<<endl;
}
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 | #include <iostream> #include <string> #include <vector> using namespace std; string increment(string in){ for(int i=in.size()-1; i>=0; i--){ if(in[i]=='9'){ in[i]='0'; } else{ in[i] += 1; return in; } } in = '1' + in; return in; } int main(){ int n; cin>>n; vector <string> seq; string a; cin>>a; n--; long long counter =0; while(n){ n--; string b; cin >> b; string c = increment(a); if(a.size()<b.size()) a = b; else if(b.size()<=c.size() && c.substr(0, b.size())==b){ counter += (c.size()-b.size()); a = c; } else { int len = a.size()-b.size(); while(len){ len--; b += '0'; counter ++; } if(a<b) a=b; else{ b += '0'; counter ++; a=b; } } } cout<<counter<<endl; } |
English