HDU 5787 K-wolf Number
题意: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的更多相关文章
- HDU 5787:K-wolf Number(数位DP)
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5787 题意:要求相邻的K个位的数不能相同,在[L,R]区间有多少个这样的数. #inclu ...
- HDU.1394 Minimum Inversion Number (线段树 单点更新 区间求和 逆序对)
HDU.1394 Minimum Inversion Number (线段树 单点更新 区间求和 逆序对) 题意分析 给出n个数的序列,a1,a2,a3--an,ai∈[0,n-1],求环序列中逆序对 ...
- HDU 6093 - Rikka with Number | 2017 Multi-University Training Contest 5
JAVA+大数搞了一遍- - 不是很麻烦- - /* HDU 6093 - Rikka with Number [ 进制转换,康托展开,大数 ] | 2017 Multi-University Tra ...
- hdu 6216 A Cubic number and A Cubic Number【数学题】
hdu 6216 A Cubic number and A Cubic Number[数学] 题意:判断一个素数是否是两个立方数之差,就是验差分.. 题解:只有相邻两立方数之差才可能,,因为x^3-y ...
- HDU 1394 Minimum Inversion Number(线段树求最小逆序数对)
HDU 1394 Minimum Inversion Number(线段树求最小逆序数对) ACM 题目地址:HDU 1394 Minimum Inversion Number 题意: 给一个序列由 ...
- HDU 5787 K-wolf Number (数位DP)
K-wolf Number 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5787 Description Alice thinks an integ ...
- HDU 4006The kth great number(K大数 +小顶堆)
The kth great number Time Limit:1000MS Memory Limit:65768KB 64bit IO Format:%I64d & %I64 ...
- HDU 5787 K-wolf Number(数位DP)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5787 [题目大意] 求区间[L,R]内十进制数相邻k位之间不相同的数字的个数. [题解] 很显然的 ...
- 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 ...
随机推荐
- js实现求平均数功能
今天在项目中遇到了一个求平均值的需求,大致需求就是,页面上面有四个input框,失去焦点就计算平均值,结果保留两位小数,并输出在页面上.不多说了,直接奉上代码,如有更好思路或者想法,都欢迎大家和我讨论 ...
- .NET AOP的实现
一.AOP实现初步 AOP将软件系统分为两个部分:核心关注点和横切关注点.核心关注点更多的是Domain Logic,关注的是系统核心的业务:而横切关注点虽与核心的业务实现无关,但它却是一种更Comm ...
- VC++ 控制台不自动退出
1.Ctrl+F5 2.结尾添加 getchar() 3.结尾添加 system("pause"); 参考:http://jingyan.baidu.com/article/555 ...
- Delphi Length函数
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...
- jQuery Moblile Demos学习记录Theming、Button、Icons图标,脑子真的不好使。
jQuery Moblile Demos学习记录Theming.Button.Icons图标,脑子真的不好使. 06. 二 / Jquery Mobile 前端 / 没有评论 本文来源于www.i ...
- 解决Eclipse编译器报错ClassNotFoundException:Org.hibernate.hql.ast.HqlToken
最近开发遇到Eclipse编译器老是报出ClassNotFoundException:Org.hibernate.hql.ast.HqlToken [from User Where id=1] 的错误 ...
- 正确看待HTML5的语法变化
也许会有人问:“HTML4已经很普及了,如果改变基础语法,会不会有什么影响?” 我们都知道,在HMTL5之前几乎没有符合标准规范的Webu浏览器!在这种情况下,各个浏览器之间的互相兼容性和互操作性在很 ...
- python3.4+pyspider爬58同城(二)
之前使用python3.4+selenium实现了爬58同城的详细信息,这次用pyspider实现,网上搜了下,目前比较流行的爬虫框架就是pyspider和scrapy,但是scrapy不支持pyth ...
- Linux下find与grep指令的相关用法
find命令 find命令的一般形式 find命令的常用选项及实例 find与xargs grep命令 grep命令的一般形式 grep正则表达式元字符集(基本集) grep命令的常用选项及实例 1. ...
- OC 代理 协议 委托 数据源的概念
(网摘) OBJC 中的 protocol 相当于 java 里的接口,delagate 就是接口的实现类(C中的回调类似 ): 数据源就是对象遵循了存储数据的协议,可以存储使用数据 协议表示了方法可 ...