题目链接:https://cn.vjudge.net/contest/278036#problem/A

具体思路:对于给定的数,我们按照位数进行运算,枚举每一位上可能的数,在枚举的时候需要注意几个条件,第一个,当前位上不能是4,第二如果前一位是6的话,当前的这一位不能是2,然后注意这个条件就可以了。

AC代码:

#include<iostream>
#include<stack>
#include<iomanip>
#include<cmath>
#include<queue>
#include<stdio.h>
#include<map>
#include<string>
#include<cstring>
using namespace std;
# define ll long long
const int maxn = 1e6+100;
int dig[10];
int dp[10];
int dfs(int len,bool fp,bool is6)//fp是用来判断是不是首位上的最大值,is6是用来判断当前的上一位是不是6
{
if(len==0)
return 1;
if(!fp&&dp[len][is6]!=-1)
return dp[len][is6];
int ans=0,fmax=fp?dig[len]:9;//如果是首位的话,只能枚举到首位,不是的话,0-9都是可以的。
for(int i=0; i<=fmax; i++)
{
if((i==4)||(is6&&i==2))
continue;
ans+=dfs(len-1,fp&&i==fmax,i==6);
}
if(!fp)
dp[len][is6]=ans;
return ans;
}
int fac(int n)
{
memset(dp,-1,sizeof(dp));
int num=0;
while(n)//把每一位取出来
{
dig[++num]=n%10;
n/=10;
}
return dfs(num,1,0);
}
int cal(int n,int m)
{
return fac(m)-fac(n);
}
int main()
{
int l,r;
while(~scanf("%d %d",&l,&r)&&(l+r))
{
printf("%d\n",cal(l-1,r));
}
return 0;
}

B题:

题目链接:https://cn.vjudge.net/contest/278036#problem/B

题目大意:让你求出1-n有多少个49,然后输出来。

具体思路:我们可以先把不满足情况的找出来,然后再总总数去减去这个数就可以了,但是要注意一点,再所有的不满足情况中,0也算是不满足的,但是要求n是大于1的,所以需要最终结果加上1.

#include<iostream>
#include<cstring>
#include<stack>
#include<stdio.h>
#include<iomanip>
#include<cmath>
#include<algorithm>
using namespace std;
# define ll long long
const int maxn = 20+5;
ll dig[maxn],dp[maxn][maxn];
ll dfs(ll len,bool fp,bool is4)
{
if(!len)
return 1;
if(!fp&&dp[len][is4]!=-1)
return dp[len][is4];
ll ans=0,fmax=fp?dig[len]:9;
for(int i=0; i<=fmax; i++)
{
if(i==9&&is4)
continue;
ans+=dfs(len-1,fp&&i==fmax,i==4);//这个地方的fp需要根据两个变量进行比较,上一位和当前的这一位。
}
dp[len][is4]=ans;
return ans;
}
ll cal(ll t)
{
memset(dp,-1,sizeof(dp));
int num=0;
while(t)
{
dig[++num]=t%10;
t/=10;
}
return dfs(num,1,0);
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
ll n;
scanf("%lld",&n);
printf("%lld\n",n-cal(n)+1);
}
return 0;
}

数位DP入门(A - 不要62 HDU - 2089 &&B - Bomb HDU - 3555 )的更多相关文章

  1. 数位dp入门 hdu2089 不要62

    数位dp入门 hdu2089 不要62 题意: 给定一个区间[n,m] (0< n ≤ m<1000000),找出不含4和'62'的数的个数 (ps:开始以为直接暴力可以..貌似可以,但是 ...

  2. HDU 2089 不要62【数位DP入门题】

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  3. hdu3555 Bomb 数位DP入门

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3555 简单的数位DP入门题目 思路和hdu2089基本一样 直接贴代码了,代码里有详细的注释 代码: ...

  4. xbz分组题B 吉利数字 数位dp入门

    B吉利数字时限:1s [题目描述]算卦大湿biboyouyun最近得出一个神奇的结论,如果一个数字,它的各个数位相加能够被10整除,则称它为吉利数.现在叫你计算某个区间内有多少个吉利数字. [输入]第 ...

  5. HDU 2089 - 不要62 - [数位DP][入门题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 Time Limit: 1000/1000 MS (Java/Others) Memory Li ...

  6. Hdu 2089 不要62 (数位dp入门题目)

    题目链接: Hdu 2089 不要62 题目描述: 给一个区间 [L, R] ,问区间内不含有4和62的数字有多少个? 解题思路: 以前也做过这个题目,但是空间复杂度是n.如果数据范围太大就GG了.今 ...

  7. HDU 2089 不要62(数位dp入门)

    题意:统计区间 [a,b] 中不含 4 和 62 的数字有多少个. 题解:这是数位DP的入门题了,首先要理解数DP的原理,DP[i][j]:代表第i位的第j值,举个栗子:如4715   数位数是从右向 ...

  8. 数位dp入门 HDU 2089 HDU 3555

    最基本的一类数位dp题,题目大意一般是在a~b的范围,满足某些要求的数字有多少个,而这些要求一般都是要包含或者不包含某些数字,或者一些带着数字性质的要求,一般来说暴力是可以解决这一类问题,可是当范围非 ...

  9. hdu:2089 ( 数位dp入门+模板)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 数位dp的模板题,统计一个区间内不含62的数字个数和不含4的数字个数,直接拿数位dp的板子敲就行 ...

随机推荐

  1. DAY2-Python学习笔记

    1.迭代器:可以直接作用于for循环的对象统称为可迭代对象:Iterable,使用isinstance()判断一个对象是否是Iterable对象: >>> from collecti ...

  2. Java 信号量 Semaphore 介绍

       Semaphore当前在多线程环境下被扩放使用,操作系统的信号量是个很重要的概念,在进程控制方面都有应用.Java 并发库 的Semaphore 可以很轻松完成信号量控制,Semaphore可以 ...

  3. Mac突然连不上WiFi

    标签(空格分隔): 杂七杂八的问题 从昨晚开始,Mac突然连不上WiFi了,人又在图书馆,上不了网好焦急.于是搜了很多方法,也不知是哪个起作用了,反正现在可以了. 步骤一 打开"Finder ...

  4. Bracket Sequences Concatenation Problem CodeForces - 990C(括号匹配水题)

    明确一下  一个字符串有x左括号不匹配  和 另一个字符串有x个右括号不匹配  这俩是一定能够匹配的 脑子有点迷 emm... 所以统计就好了  统计x个左括号的有几个,x个右括号的有几个 然后 乘一 ...

  5. oracle 月份中日的值必须介于 1 和当月最后一日之间

    解决方法: 1.用时间字段去关联字符串字段导致此错误.. 如果1.解决不了就看 2.把date'2017-01-01'  换成 to_date('2017-01-01','yyyy-mm-dd')

  6. 【转】VS2012简单的使用感受+插件推荐

    转自:http://blog.sina.com.cn/s/blog_58c506600101b34t.html ~PS:后面有博主自己补充的VS2013的哦~ 1.Visual Studio Achi ...

  7. BZOJ3112 [Zjoi2013]防守战线 【单纯形】

    题目链接 BZOJ3112 题解 同志愿者招募 费用流神题 单纯形裸题 \(BZOJ\)可过 洛谷被卡.. #include<algorithm> #include<iostream ...

  8. 洛谷 P1878 舞蹈课 解题报告

    P1878 舞蹈课 题目描述 有\(n\)个人参加一个舞蹈课.每个人的舞蹈技术由整数来决定.在舞蹈课的开始,他们从左到右站成一排.当这一排中至少有一对相邻的异性时,舞蹈技术相差最小的那一对会出列并开始 ...

  9. 【bzoj3598】 Scoi2014—方伯伯的商场之旅

    http://www.lydsy.com/JudgeOnline/problem.php?id=3598 (题目链接) 题意 Solution 原来这就是极水的数位dp,呵呵= =,感觉白学了.htt ...

  10. [NOI2012]美食节——费用流(带权二分图匹配)+动态加边

    题目描述 小M发现,美食节共有n种不同的菜品.每次点餐,每个同学可以选择其中的一个菜品.总共有m个厨师来制作这些菜品.当所有的同学点餐结束后,菜品的制作任务就会分配给每个厨师.然后每个厨师就会同时开始 ...