HDU 2089:不要62(数位DP)
来源:互联网 发布:Windows网卡绑定模式 编辑:程序博客网 时间:2024/05/16 06:26
问题概述:规定不吉利的数字为所有含有4或62的号码,例如:62315 73418 88914都属于不吉利号码,但如果6和
2不连续就不算,给定一个区间,求出这个区间有多少个数不是不吉利数
(http://acm.hust.edu.cn/vjudge/problem/23625/origin)
输入样例: 对应输出:
1 100 800 0
题解:
dp[i][0]:在第i+1位不为6的时候前i位有多少种不同状态使得整个数为不吉利数
dp[i][1]:在第i+1位为6的时候前i位有多少种不同状态使得整个数为不吉利数
dp[i][2]:前i位有多少种不同的状态(显然dp[i][2]==10^i)
bit[12]:bit[k]表示第k位的数
转移方程:
对于第i位每一种可能且合法的数
{
如果第i位为4 || i+1位是6第i位是2 || 当前状态为dp[][2]
dp[i][x] += dp[i-1][2]
否则如果第i位是6,
dp[i][x] += dp[i-1][1]
以上都不是
dp[i][x] += dp[i-1][0]
}
#include<stdio.h>#include<string.h>#include<algorithm>using namespace std;int bit[12];int dp[12][3];int Sech(int pos, int st, int flag)/*flag==1表示当前位不能循环到9,即如果当前位为9,则会使整个数超过n*/{int ans, u, d;if(pos==0){if(st==2)return 1;return 0;}if(flag && dp[pos][st]!=-1)return dp[pos][st];ans = 0;u = flag==0? bit[pos]:9;for(d=0;d<=u;d++){if(st==2 || d==4 || (st==1 && d==2))ans += Sech(pos-1, 2, flag || d<u);else if(d==6)ans += Sech(pos-1, 1, flag || d<u);elseans += Sech(pos-1, 0, flag || d<u);}if(flag)dp[pos][st] = ans;return ans;}int Jud(int n){int len;len = 0;while(n){bit[++len] = n%10;n /= 10;}return Sech(len, 0, 0);}int main(void){int n, m;memset(dp, -1, sizeof(dp));while(scanf("%d%d", &n, &m), n!=0 || m!=0){printf("%d\n", m-n+1-(Jud(m)-Jud(n-1)));//printf("%d %d %d\n", dp[2][0], dp[2][1], dp[2][2]);}return 0;}
1 0
- hdu 2089 不要62(数位dp)
- hdu 2089(不要62)数位DP
- HDU-#2089不要62(数位DP)
- hdu 2089 不要62 (数位dp)
- HDU 2089 不要62(数位 dp)
- hdu 2089 不要62(数位DP)
- HDU 2089 不要62(数位DP)
- hdu 2089 不要62(数位dp)
- hdu 2089 不要62(数位dp)
- HDU 2089 不要62(数位DP)
- HDU 2089 不要62(数位dp)
- HDU 2089 不要62(数位DP)
- hdu 2089 不要62(数位dp)
- HDU 2089 不要62 (数位DP)
- hdu 2089 不要62(数位dp)
- hdu 2089 不要62 (数位DP)
- 【HDU 2089】不要62(数位dp)
- HDU-2089 不要62 (数位DP)
- 将Datatable一分为二
- #android#activity
- android studio onTouch触摸事件
- java 值传递和引用传递二
- 文章标题
- HDU 2089:不要62(数位DP)
- ActiveMQ简单介绍以及安装
- java中的重载与重写
- [Vijos1057] 盖房子
- tools:context用法
- 安卓控件之图片控件(ImagView)
- C# attribute(特性)
- 存储过程中的 SET XACT_ABORT ON 和事务
- 结构型模式之——组合模式