题意:l-r之间有多少个数,其连续k位不存在相同的数字

分析:数位dp,从高位开始向低位进行枚举。因为连续k个数字不相同,在枚举一个数字的时候,

要知道前k-1位的内容,这可以用一个4维的数组表示,再一点,前缀0的存在,

要区分现在枚举该位的0是不是前缀0,用一个标志记录bo就行,还有一点,就是前面

枚举的是不是比上限要小,比如统计255,如果第一个枚举1,那么剩下两位怎么放

都行,如果是2,那么加一个控制f,判断是否是否前面比上限小

*/

输入:

1 1 2
20 100 5

输出:

1
72

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

ll L,R,k;

int d[20];

ll dp[20][12][12][12][12];

ll dfs(int dep,int f,int now[],int bo) {

int x = now[0], y = now[1], z = now[2], e = now[3];

if(dep < 0) return 1;

if(f&&dp[dep][x][y][z][e]!=-1) return dp[dep][x][y][z][e];

if(f){

ll& ret = dp[dep][x][y][z][e];

ret=0;

for(int i = 0; i <= 9; ++i) {

int OK = 1;

for(int j = 0; j < k-1; ++j) if(now[j] == i) {OK = 0; break;}

if(OK == 0) continue;

if(!bo && !i)  ret += dfs(dep-1,1,now,0);

else {

int tmpnow[6];

for(int j = 0; j <= 4; ++j) tmpnow[j] = now[j+1];

tmpnow[5] = 10;

tmpnow[k-2] = i;

ret += dfs(dep-1,1,tmpnow,1);

}

}

return ret;

}else {

ll ret = 0;

for(int i = 0; i <= d[dep]; ++i) {

int OK = 1;

for(int j = 0; j < k-1; ++j) if(now[j] == i) {OK = 0; break;}

if(OK == 0) continue;

if(!bo && !i)  ret += dfs(dep-1,i<d[dep],now,0);

else {

int tmpnow[6];

for(int j = 0; j <= 4; ++j) tmpnow[j] = now[j+1];

tmpnow[5] = 10;

tmpnow[k-2] = i;

ret += dfs(dep-1,i<d[dep],tmpnow,1);

}

}

return ret;

}

}

ll solve(ll x) {

memset(dp,-1,sizeof(dp));

int len = 0;

while(x) {

d[len++] = x % 10;

x /= 10;

}

int now[6];

for(int i = 0; i <= 5; ++i) now[i] = 10;

return dfs(len-1,0,now,0);

}

int main(){

while(cin>>L>>R>>k)

cout<<solve(R)-solve(L-1)<<endl;

return 0;

}

HDU 5787 K-wolf Number的更多相关文章

  1. HDU 5787:K-wolf Number(数位DP)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5787 题意:要求相邻的K个位的数不能相同,在[L,R]区间有多少个这样的数. #inclu ...

  2. HDU.1394 Minimum Inversion Number (线段树 单点更新 区间求和 逆序对)

    HDU.1394 Minimum Inversion Number (线段树 单点更新 区间求和 逆序对) 题意分析 给出n个数的序列,a1,a2,a3--an,ai∈[0,n-1],求环序列中逆序对 ...

  3. HDU 6093 - Rikka with Number | 2017 Multi-University Training Contest 5

    JAVA+大数搞了一遍- - 不是很麻烦- - /* HDU 6093 - Rikka with Number [ 进制转换,康托展开,大数 ] | 2017 Multi-University Tra ...

  4. hdu 6216 A Cubic number and A Cubic Number【数学题】

    hdu 6216 A Cubic number and A Cubic Number[数学] 题意:判断一个素数是否是两个立方数之差,就是验差分.. 题解:只有相邻两立方数之差才可能,,因为x^3-y ...

  5. HDU 1394 Minimum Inversion Number(线段树求最小逆序数对)

    HDU 1394 Minimum Inversion Number(线段树求最小逆序数对) ACM 题目地址:HDU 1394 Minimum Inversion Number 题意:  给一个序列由 ...

  6. HDU 5787 K-wolf Number (数位DP)

    K-wolf Number 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5787 Description Alice thinks an integ ...

  7. HDU 4006The kth great number(K大数 +小顶堆)

    The kth great number Time Limit:1000MS     Memory Limit:65768KB     64bit IO Format:%I64d & %I64 ...

  8. HDU 5787 K-wolf Number(数位DP)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5787 [题目大意] 求区间[L,R]内十进制数相邻k位之间不相同的数字的个数. [题解] 很显然的 ...

  9. HDU 5787 K-wolf Number 数位DP

    K-wolf Number Problem Description   Alice thinks an integer x is a K-wolf number, if every K adjacen ...

随机推荐

  1. vs2013 JS代码提示

    1.JS提示 在Js文件头部加 /// <reference path="ext-all-dev.js" /> 要求引用的js和本js在同一目录,否则需要全部路径

  2. iOS 之URL schemes

    添加 URL  schemes 步骤: 1.打开info.plist文件. 2.点击 “+ ”号添加,或者在列表上点击鼠标右键,选择 Add Row. 3.选择 URL types. 4.点击三角号展 ...

  3. ios 网络数据下载和JSON解析

    ios 网络数据下载和JSON解析 简介 在本文中笔者将要给大家介绍ios中如何利用NSURLConnection从网络上下载数据,如何解析下载下来的JSON数据格式,以及如何显示数据和图片的异步下载 ...

  4. POJ 2195 Going Home / HDU 1533(最小费用最大流模板)

    题目大意: 有一个最大是100 * 100 的网格图,上面有 s 个 房子和人,人每移动一个格子花费1的代价,求最小代价让所有的人都进入一个房子.每个房子只能进入一个人. 算法讨论: 注意是KM 和 ...

  5. Niagara AX之在Station下显示Home节点

    默认的Station下是没有Home节点的,那么,这个Home节点是怎么添加上去的呢? 注意Home后面的描述(Description):“Navigation tree defined by nav ...

  6. O(1)时间删除链表节点

    问题描述:给定单相链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点. 这个比较简单,做不做解释,直接看参考代码,不过有一点就是要注意,还是要看删除的节点类型,不能保证总是O(1)时间 ...

  7. Android动态加载代码技术

    Android动态加载代码技术 在开发Android App的过程当中,可能希望实现插件式软件架构,将一部分代码以另外一个APK的形式单独发布,而在主程序中加载并执行这个APK中的代码. 实现这个任务 ...

  8. 基于VMware的eCos应用程序测试(hello wold)

    (1)脚本配置ecosconfig new pccdl_component CYG_HAL_STARTUP { # Flavor: data # No user value, uncomment th ...

  9. linux下tar用法

    以下是linux下tar的用法,转一下,以便方便自己看(这里没把rar,zip类的转过来,一般rar,zip在linux下基本没人用,基本上是zip,unzip,rar,unrar,这些命令,并且ra ...

  10. Pet(hdu 4707 BFS)

    Pet Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...