zoukankan      html  css  js  c++  java
  • 【数位DP】HDU 2089 不要62

    http://acm.hdu.edu.cn/showproblem.php?pid=2089

    【AC】

     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 typedef long long ll;
     4 const int maxn=1e6+2;
     5 int dp[10][10];
     6 int digit[10];
     7 int cnt;
     8 int ans;
     9 int n,m;
    10 bool check()
    11 {
    12     for(int i=0;i<cnt;i++)
    13     {
    14         if(digit[i]==4) return false;
    15         if(digit[i]==2&&digit[i+1]==6) return false;
    16     }
    17     return true;
    18     
    19 }
    20 void init()
    21 {
    22     memset(dp,0,sizeof(dp));
    23     dp[0][0]=1;
    24     for(int i=1;i<=7;i++)
    25     {
    26         for(int j=0;j<=9;j++)
    27         {
    28             if(j==4) continue;
    29             for(int k=0;k<=9;k++)
    30             {
    31                 if(j==6&&k==2) continue;
    32                 dp[i][j]+=dp[i-1][k];
    33             }
    34         }
    35     } 
    36 }
    37 bool judge(int pos)
    38 {
    39     for(int i=cnt;i>=pos-1;i--)
    40     {
    41         if(digit[i]==4) return false;
    42         if(i-1>=pos-1&&digit[i]==6&&digit[i-1]==2) return false; 
    43     } 
    44     return true;
    45 }
    46 void calc(int x)
    47 {
    48     cnt=0;
    49     while(x)
    50     {
    51         digit[cnt++]=x%10;
    52         x/=10;
    53     }
    54     digit[cnt]=0;
    55 }
    56 void solve(int pos)
    57 {
    58     if(pos==0) return;
    59     int t=digit[pos-1];
    60     for(int i=0;i<t;i++)
    61     {
    62         if(i==4) continue;
    63         if(i==2&&digit[pos]==6) continue;
    64         ans+=dp[pos][i];
    65      } 
    66     if(judge(pos))
    67     {
    68         solve(pos-1);
    69     }
    70     return;
    71 }
    72 
    73 int query(int x)
    74 {
    75     calc(x);
    76     ans=0;
    77     solve(cnt);
    78     if(check())
    79     {
    80         ans++;
    81     }
    82     return ans;
    83 }
    84 int main()
    85 {
    86     init();
    87     while(~scanf("%d%d",&n,&m))
    88     {
    89         if(n+m==0) break;
    90         int res=query(m)-query(n-1);
    91         printf("%d
    ",res);
    92     }
    93     return 0;
    94 }
    View Code
  • 相关阅读:
    委托
    Ajax TreeView绑定数据库(一)
    递归算法算出1,1,2,3,5.........(二)
    Ajax技术之深入浅出
    javasript读写xml
    递归算法求阶乘(一)
    关于.Net中的实际开发
    ASP.NET Form表单验证
    js 实现自动合并相同的行
    递归快速排序
  • 原文地址:https://www.cnblogs.com/itcsl/p/7392503.html
Copyright © 2011-2022 走看看