hdu2089 不要62 数位DP

Posted 奚政

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hdu2089 不要62 数位DP相关的知识,希望对你有一定的参考价值。

数字中不能出现4或者连续的62,数位DP裸题

 1 #include<stdio.h>
 2 #include<string.h>
 3 long long ans;
 4 bool a[1000000];
 5 void fun(){
 6     for(long long i=0;i<=1000000;i++){
 7         bool f1=0,f2=1;
 8         for(long long n=i;n>0;n/=10){
 9             int a=n%10;
10             if((a==4)||(f1&&a==6)){
11                 f2=0;
12                 break;
13             }
14             else if(a==2){
15                 f1=1;
16             }
17             else if(f1||a!=6){
18                 f1=0;
19             }
20         }
21         if(f2)a[i]=1;
22     }
23 
24     return;
25 }
26 int main(){
27     long long n,m;
28     memset(a,0,sizeof(a));
29     fun();
30     while(scanf("%I64d%I64d",&n,&m)!=EOF&&(n!=0||m!=0)){
31         ans=0;
32         for(long long i=n;i<=m;i++){
33             if(a[i])ans++;
34         }
35         printf("%I64d\\n",ans);
36     }
37     return 0;
38 }
View Code

 

以上是关于hdu2089 不要62 数位DP的主要内容,如果未能解决你的问题,请参考以下文章

HDU2089 ------不要62(数位dp)

HDU 2089 不要62(数位DP)

hdu 2089 不要62数位dp

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

HDU2089 不要62[数位DP]

hdu2089不要62(数位dp)