#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; } |