bzoj1833

http://www.lydsy.com/JudgeOnline/problem.php?id=1833

2.5个小时就花在这上面了。。。

水到200题了。。。然并卵,天天做水题有什么前途。。。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll A, B;
ll dp[20][20][20], a[20], ret[20], ans[20], bin[20];
void solve(ll n, int f)
{
    int len = 0; ll t = n; memset(a, 0, sizeof(a)); memset(ret, 0, sizeof(ret));
    while(n) a[++len] = n % 10, n /= 10;
    for(int i = 1; i < len; ++i) 
        for(int j = 1; j <= 9; ++j) 
            for(int k = 0; k <= 9; ++k) ret[k] += dp[i][j][k]; 
//    for(int i = 1; i < a[len]; ++i)
//        for(int j = 0; j <= 9; ++j) ret[j] += dp[len][i][j];
    for(int i = len; i; --i)
    {
        for(int j = 0; j < a[i]; ++j) 
        {
            if(!j && i == len) continue;
            for(int k = 0; k <= 9; ++k) ret[k] += dp[i][j][k];
        }
        ret[a[i]] += t % bin[i] + 1;
    }
    for(int i = 0; i <= 9; ++i) ans[i] += f * ret[i];
}
int main()
{
//    freopen("countzj.in", "r", stdin);
//    freopen("countzj.out", "w", stdout);
    bin[1] = 1ll; for(int i = 2; i <= 13; ++i) bin[i] = bin[i - 1] * 10ll;
    for(int i = 0; i <= 9; ++i) dp[1][i][i] = 1;
    for(int i = 2; i <= 13; ++i)
        for(int j = 0; j <= 9; ++j) 
            for(int k = 0; k <= 9; ++k) 
                for(int l = 0; l <= 9; ++l) dp[i][j][l] += dp[i - 1][k][l] + (ll)(j == l) * bin[i - 1];
    scanf("%lld%lld", &A, &B);
    solve(B, 1); solve(A - 1, -1);
    for(int i = 0; i <= 8; ++i) printf("%lld ", ans[i]); 
    printf("%lld\n", ans[9]);
//    fclose(stdin); fclose(stdout);
    return 0;
}
View Code

 

posted @ 2017-05-20 13:08  19992147  阅读(138)  评论(0编辑  收藏  举报