CodeTyper

Codeforces, Contest 1036: C. Classy Numbers (Digit Dynamic Programming)

Feb 26th, 2021
132
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.19 KB | None | 0 0
  1. #include<bits/stdc++.h>
  2.  
  3. #define boost ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL)
  4. #define Bye return 0
  5. #define CodeTyper main
  6. #define ll int long long
  7.  
  8. using namespace std;
  9.  
  10. ll dp[20][2][10];
  11.  
  12. ll digit_dp(int pos, int flag, int sum, string str){
  13.     if(sum > 3)
  14.         return 0;
  15.  
  16.     if(pos == str.size())
  17.         return 1;
  18.  
  19.     if(dp[pos][flag][sum] != -1)
  20.         return dp[pos][flag][sum];
  21.  
  22.     ll res = 0;
  23.     int end = flag ? str[pos] - '0' : 9;
  24.     for (int j = 0; j <= end; j++){
  25.         int new_flag = (j == str[pos] - '0') ? flag : 0;
  26.         res += digit_dp(pos + 1, new_flag, sum + (j != 0), str);
  27.     }
  28.  
  29.     return dp[pos][flag][sum] = res;
  30. }
  31.  
  32. void reset_dp(){
  33.     memset(dp, -1, sizeof dp);
  34. }
  35.  
  36. void solve() {
  37.     ll a, b; cin>>a>>b; a--;
  38.     string str_b = to_string(b);
  39.     string str_a = to_string(a);
  40.  
  41.     reset_dp();
  42.     ll r = digit_dp(0, 1, 0, str_b);
  43.     reset_dp();
  44.     ll l = digit_dp(0, 1, 0, str_a);
  45.  
  46.     l = a < 0 ? 0 : l;
  47.  
  48.     cout<<(r - l)<<endl;
  49. }
  50.  
  51. int CodeTyper()
  52. {
  53.     boost;
  54.     int t; cin>>t;
  55.     while(t--)
  56.         solve();
  57.     Bye;
  58. }
  59.  
  60. /*
  61.     'Think FIRST, then CODE.'
  62.     'May the CODE be with YOU.'
  63. */
Advertisement
Add Comment
Please, Sign In to add comment