基础的数位dp,才发现今天才终于彻底搞懂了数位dp。。。

//
// main.cpp
// hdu5787.1
//
// Created by New_Life on 16/8/10.
// Copyright © 2016年 chenhuan001. All rights reserved.
// #include <iostream>
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
using namespace std; long long dp[][][];
int k;
int mod; long long dfs(int wei[],int p,int flag,long long pre,int pk)
{
if(p<) return ;
if(flag == && dp[p][pk][pre]!= -) return dp[p][pk][pre];
int mark[];
int twei[];
memset(mark,,sizeof(mark));
memset(twei,,sizeof(twei));
long long tp = pre;
int cnt = ;
while(tp)
{
twei[ cnt++ ] = tp%;
tp/=;
}
for(int i=;i<pk;i++) mark[twei[i]]++; if(flag == )
{
long long sum = ;
for(int i=;i<wei[p];i++)
{
if(pk== && i==)
{
sum += dfs(wei,p-,,,);
}
else
{
if(mark[i]==)
sum += dfs(wei,p-,,(pre*+i)%mod,min(pk+,k-));
}
}
if(mark[wei[p]]==) sum += dfs(wei,p-,,(pre*+wei[p])%mod,min(pk+,k-));
return sum;
}
else
{
long long sum = ;
for(int i=;i<=;i++)
{
if(pk== && i==)
{
sum += dfs(wei,p-,,,);
}
else
{
if(mark[i]==)
{
sum += dfs( wei,p-,,(pre*+i)%mod,min(pk+,k-) );
}
}
}
return dp[p][pk][pre]=sum;
}
} long long get(long long x)
{
if(x==) return ;
memset(dp,-,sizeof(dp));
int wei[];
int cnt = ;
while(x)
{
wei[cnt++] = x%;
x /= ;
}
return dfs(wei,cnt-,,,);
} int main(int argc, const char * argv[]) {
long long L,R;
while (cin>>L>>R>>k) {
mod = (int)pow(10.0,k-);
cout<<get(R)-get(L-)<<endl;
// int ans = 0;
// for(int i=L;i<=R;i++)
// {
// int wei[10];
// memset(wei, 0, sizeof(wei));
// int ti = i;
// int cnt = 0;
// while(ti)
// {
// wei[ cnt++ ] = ti%10;
// ti/=10;
// }
// int flag = 0;
// for(int j=1;j<cnt;j++)
// {
// for(int p=1;p<k;p++)
// {
// if(j-p>=0 && wei[j-p]==wei[j] )
// {
// flag = 1;
// break;
// }
// }
// if(flag) break;
// }
// if(flag == 0) ans++;
// }
// printf("right: %d\n",ans);
}
return ;
}
/*
1 1 2
20 100 5
101 101 3
100 200 2
*/

hdu5787(数位dp)的更多相关文章

  1. 多校5 HDU5787 K-wolf Number 数位DP

    // 多校5 HDU5787 K-wolf Number 数位DP // dp[pos][a][b][c][d][f] 当前在pos,前四个数分别是a b c d // f 用作标记,当现在枚举的数小 ...

  2. HDU5787 K-wolf Number 数位dp

    分析:赛场上也知道是裸的数位dp,但是无奈刷数位dp题刷的太少了,并不能写出来 一点感想:赛后补题,看了题解的map记录状态,一脸蒙逼,也是非常的不爽,然后想看别人写的,不是递归就是写的比较乱 而且我 ...

  3. 【BZOJ1662】[Usaco2006 Nov]Round Numbers 圆环数 数位DP

    [BZOJ1662][Usaco2006 Nov]Round Numbers 圆环数 Description 正如你所知,奶牛们没有手指以至于不能玩"石头剪刀布"来任意地决定例如谁 ...

  4. bzoj1026数位dp

    基础的数位dp 但是ce了一发,(abs难道不是cmath里的吗?改成bits/stdc++.h就过了) #include <bits/stdc++.h> using namespace ...

  5. uva12063数位dp

    辣鸡军训毁我青春!!! 因为在军训,导致很长时间都只能看书yy题目,而不能溜到机房鏼题 于是在猫大的帮助下我发现这道习题是数位dp 然后想起之前讲dp的时候一直在补作业所以没怎么写,然后就试了试 果然 ...

  6. HDU2089 不要62[数位DP]

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  7. 数位DP GYM 100827 E Hill Number

    题目链接 题意:判断小于n的数字中,数位从高到低成上升再下降的趋势的数字的个数 分析:简单的数位DP,保存前一位的数字,注意临界点的处理,都是套路. #include <bits/stdc++. ...

  8. 数位dp总结

    由简单到稍微难点. 从网上搜了10到数位dp的题目,有几道还是很难想到的,前几道基本都是模板题,供入门用. 点开即可看题解. hdu3555 Bomb hdu3652 B-number hdu2089 ...

  9. 数位DP入门

    HDU 2089 不要62 DESC: 问l, r范围内的没有4和相邻62的数有多少个. #include <stdio.h> #include <string.h> #inc ...

随机推荐

  1. c# Beginlnvoke 委托

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  2. C#中的异步和同步

    同步 同步(英语:Synchronization [ˌsɪŋkrənaɪ'zeɪʃn]),指对在一个系统中所发生的事件(event)之间进行协调,在时间上出现一致性与统一化的现象.说白了就是多个任务一 ...

  3. android 引入phonegap

    步骤: 1.复制cordova-2.9.0.jar 到lib文件下 2.在assets文件下创建www文件夹及其cordova.js .jquery.js.jquery.mobile-1.3.2.cs ...

  4. Java中自定义异常

    /*下面做了归纳总结,欢迎批评指正*/ /*自定义异常*/ class ChushulingException extends Exception { public ChushulingExcepti ...

  5. C#中Struct与Class的区别

    class和struct最本质的区别是class是引用类型,而struct是值类型,它们在内存中的分配情况有所区别. 什么是class? class(类)是面向对象编程的基本概念,是一种自定义数据结构 ...

  6. 在Spring中使用脚本

    Spring支持3中不同的脚本语言(看来支持地还挺多的嘛):JRuby.Groovy和BeanShell. 这三个都是java社区的脚本语言(反正到目前为止我一个都没用过,可见我有多挫). JRuby ...

  7. Metasploit中使用Nessus插件命令

    基本命令 导入扫描结果 db_import  /路径/文件.nessus 查看数据库里面现有的IP信息 msf > db_hosts -c address,svcs,vulns(注:vulns是 ...

  8. 浏览器被hao.360.cn劫持怎么办

    特么的现在互联网太没节操了,一大早发现我的浏览器被hao.360.cn劫持了,弄了好久都没弄好,后来一想可能是因为qvod的原因,这可是哥当年看片的神器啊…… 废话不说: 1,进入:C:\Progra ...

  9. Codeforces Round #243 (Div. 2) B(思维模拟题)

    http://codeforces.com/contest/426/problem/B B. Sereja and Mirroring time limit per test 1 second mem ...

  10. 最近用到这个强大的工具 PhysicsEditor (转)

    今天收到PhysicsEditor作者发过来的license key,所以顺便把PhysicsEditor也尝试了一下.主要是尝试将PhysicsEditor与cocos2dx,box2d结合开发的一 ...