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).杭州交通管理局经常会扩充一些的士车牌照,新 ...
随机推荐
- js_2_json
js如何使用json? json.stringify(需要序列化对象) // 序列化 josn.parse(已经序列化对象) // 反序列化
- xml格式字符串转为Map
import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.Element;import org.dom ...
- 【Java】泛型学习笔记
参考书籍 <Java核心技术:卷1> 泛型, 先睹为快 先通过一个简单的例子说明下Java中泛型的用法: 泛型的基本形式类似于模板, 通过一个类型参数T, 你可以"私人定制&qu ...
- 【COOKIE 与 SESSION】
一.相关概念 cookie的出现,解决http协议无状态特性 由于http协议无法保持状态,但实际情况,我们却又需要"保持状态",因此cookie就是在这样一个场景下诞生. 举例: ...
- Jmeter之性能测试插件PerfMon Metrics Collector监听器,实时监听服务器资源(十四)
Servers Performance Monitoring Introduction During a load test, it is important to know the health o ...
- IntelliJ IDEA(七) :Project Structure
Project Structure “ 项目结构”对话框允许您管理项目和IDE级别的元素,例如Modules,Facets,Libraries, Artifacts和SDK. 在大多数情况下,左边部分 ...
- dubbo refrence bean(服务引用)
在xml上写一个dubbo标签就可以把远程的服务引用到本地使用: <dubbo:reference id="buyFoodService" interface="c ...
- 洛谷 [P2486] 染色
树剖+线段树维护连续相同区间个数 注意什么时候长度要减一 #include <iostream> #include <cstdio> #include <cstdlib& ...
- BZOJ 2631: tree [LCT splay区间]
2631: tree Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 3854 Solved: 1292[Submit][Status][Discus ...
- 【转】 C/C++程序员必须熟练应用的开源项目
作为一个经验丰富的C/C++程序员, 肯定亲手写过各种功能的代码, 比如封装过数据库访问的类, 封装过网络通信的类,封装过日志操作的类, 封装过文件访问的类, 封装过UI界面库等, 也在实际的项目中应 ...