hdu2089 不要62--经典数位DP
一道十分经典的数位DP的题目。
dp[i][j]表示最高位是数字i,连同最高位在内共有j位。注意边界的初始化。
接下来就是区间划分,特殊情况处理.....对了,如果不知道自己的方法是否正确,可以写一个测试函数:
bool check(int n){ //判断n是否符合条件
int a[20];
int c=0;
while(n>0){
a[c++]=n%10;
n/=10;
}
for(int i=0;i<c;++i) if(a[i]==4) return false;
for(int i=0;i<c-1;++i){
if(a[i]*10+a[i+1]==26) return false;
}
return true;
}
inline int solve(int n){ //可以求得0~n之间有多少符合条件的数
int ans=0;
for(int i=0;i<=n;++i)
if(check(i)) ++ans;
return ans;
}
AC代码:
#include<cstdio>
#include<cstring>
#include<cmath>
const int maxn=20;
int dp[10][maxn];
void deal(){
memset(dp,0,sizeof(dp));
//初始化边界
for(int i=0;i<10;++i){
if(i==4) continue;
else dp[i][1]=1;
}
for(int i=2;i<10;++i){ //length
for(int j=0;j<10;++j){
if(j==4) continue;
for(int k=0;k<10;++k){
dp[j][i]+=dp[k][i-1];
}
}
dp[6][i]-=dp[2][i-1];
}
}
inline int solve(int pre,int n,int len){
if(pre==62||pre%10==4||pre/10==4) return 0;
if(len==1){
int ans=0;
for(int i=0;i<=n;++i)
if(i==4) continue;
else ++ans;
if(pre%10==6&&n>=2) --ans;
return ans;
}
int ans=0;
int m=(int)pow(10,len-1);
int up=n/m;
for(int i=0;i<up;++i){
ans+=dp[i][len];
}
if(pre%10==6&&up>2) ans-=dp[2][len];
return ans+solve(pre%10*10+up,n%m,len-1);
}
inline int getlen(int n){
if(n==0) return 1;
int c=0;
while(n>0){
n/=10;
++c;
}
return c;
}
int main(){
deal();
int l,r;
while(scanf("%d%d",&l,&r)!=EOF&&l&&r){
int a=solve(0,r,getlen(r));
int b=solve(0,l-1,getlen(l-1));
//printf("%d-%d=%d\n",a,b,a-b);
printf("%d\n",a-b);
}
return 0;
}
如有不当之处欢迎指出!
hdu2089 不要62--经典数位DP的更多相关文章
- ☆ [HDU2089] 不要62「数位DP」
类型:数位DP 传送门:>Here< 题意:问区间$[n,m]$的数字中,不含4以及62的数字总数 解题思路 数位DP入门题 先考虑一般的暴力做法,整个区间扫一遍,判断每个数是否合法并累计 ...
- HDU2089 ------不要62(数位dp)
不要62 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU2089 不要62 题解 数位DP
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 题目大意:求区间 \([l,r]\) 范围内不包含数字"4"且不包含连续的数 ...
- hdu2089不要62(数位dp)
#include <stdio.h> #include <string.h> ][]; ]; /* dp[i][0] 不含62,4 dp[i][1] 2开头 dp[i][2] ...
- HDU 2089 不要62(数位dp入门)
题意:统计区间 [a,b] 中不含 4 和 62 的数字有多少个. 题解:这是数位DP的入门题了,首先要理解数DP的原理,DP[i][j]:代表第i位的第j值,举个栗子:如4715 数位数是从右向 ...
- HDU 2089 不要62 【数位dp】
<题目链接> 不要62 Problem Description 杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer).杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照 ...
- HDU 2089 不要62(数位dp模板题)
http://acm.hdu.edu.cn/showproblem.php?pid=2089 题意:求区间内不包含4和连续62的数的个数. 思路: 简单的数位dp模板题.给大家推荐一个好的讲解博客.h ...
- HDU 2089 不要62【数位DP入门题】
不要62 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- 【ACM】不要62 (数位DP)
题目:http://acm.acmcoder.com/showproblem.php?pid=2089 杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer).杭州交通管理局经常会扩充一些的士车牌照,新 ...
随机推荐
- Servlet--HttpServletResponse的2个操作流的方法
前面已经说过无数多次了,我们的项目都是基于HTTP协议的一次请求,一次响应.实际编码中,我们在处理完逻辑后一般是跳转到一个页面上,或者用输出流返回json字符串.其实跳转到一个页面往往也就是JSP,J ...
- android 中string.xml中的%1$s
idView.setText(getString(R.string.estate_id, mCollectParamObj.getPlotNo())); estate_id:小区号%1$s %d ...
- TP手册学习第四内置天
比较标签: eq:等于 heq:恒等于 gt:大于 lt:小于 (前面加上n则为否,如neq表示不等于)使用方法:{gt name="name" value= ...
- php的print_r第二个参数是true有啥用啊
print_r(); 第二个参数 为true时 返回值 而不显示. echo ,print,print_r的区别 echo ,print的区别在于echo 可以输出多个变量值,而print只有一个变量 ...
- java to kotlin (2) - lambda编程
前言 Kotlin Note 是我学习kotlin整理笔记向博客,文章中的例子参考了kotlin in action这本书籍,同时我也极力推荐这本书,拥有Java基础的人可以很快的就使用kotlin来 ...
- [TCP/IP]TCP连接的建立和终止
TCP 是支持全双工通信的传输层协议,为了开发出更好的网络通信应用,清楚了解其中的交互过程是非常必要的. 下面用比较直白的话来描述&理解一下这个过程: TCP 连接建立:三次握手 服务器依次调 ...
- 浅探element-ui2组件源码之upload
最近不小心更新了element-ui的版本,已经到了2.1.0,以前修改的源码都失效了. 于是重新尝试下面的指令重新修改: git clone https://github.com/ElemeFE/e ...
- c# 可变字符串 StringBuilder
普通的string不可变,除非用+ 但是+两个字符串后 会生成一个新的string实例.会在内存中创建新的字符串对象.如果重复的对字符串修改,将极大的增加内存开销.c#提供了个可变的字符串序列Stri ...
- 缓存之ehcache
1.EhCache缓存框架简介 EhCache 是一个纯Java的进程内缓存框架,具有快速.精干等特点,是Hibernate中默认的CacheProvider. 我们使用EhCache缓存框架主要是为 ...
- ABP官方文档翻译 5.1 Web API控制器
ASP.NET Web API控制器 介绍 AbpApiController基类 本地化 其他 过滤器 审计日志 授权 反伪造过滤器 工作单元 结果包装和异常处理 结果缓存 校验 模型绑定器 介绍 A ...