hdu5898 odd-even number 沈阳网络赛1007

这题是数位dp,我不会哼哼,但是队友会,上了个厕所就被a出来了, 微笑转载自队友博客:http://blog.csdn.net/qq_34872380/article/details/52588809  点击打开链接

题意有点绕,odd-even数就是一个数  比方11222 就是,因为连续奇数的长度为2 而连续偶数的长度为3,但是11222333不行,因为3个3不满足连续奇数为偶数长度的条件。
数位DP,dp[len][pre][e] 代表第几位,之前一位是奇数还是偶数,e表示是否还要添加一个与pre同为奇数或者偶数的数。


[html]  view plain  copy
 print ?
  1. #include <iostream>  
  2. #include <cstdio>  
  3. #include <cstring>  
  4. using namespace std;  
  5. long long int dp[20][2][2];  
  6. int a[20];  
  7. long long int dfs(int len,int pre,int e,bool flag,bool s)  
  8. {  
  9.     if(len<0)  
  10.     {  
  11.         return e==1?0:1;  
  12.     }  
  13.     if(flag==false&&dp[len][pre][e]!=-1&&s)  
  14.     {  
  15.         return dp[len][pre][e];  
  16.     }  
  17.     long long int ans=0;  
  18.     int cnt=flag?a[len]:9;  
  19.     for(int i=0; i<=cnt; i++)  
  20.     {  
  21.         if(s==false)  
  22.         {  
  23.             if(i==0)  
  24.                 ans+=dfs(len-1,0,0,flag&&i==cnt,false);  
  25.             else  
  26.             {  
  27.                 ans+=dfs(len-1,i%2,i%2==1?1:0,flag&&i==cnt,true);  
  28.             }  
  29.         }  
  30.         else if(i%2==1)  
  31.         {  
  32.             if(pre%2==1)  
  33.                 ans+= dfs(len-1,1,e^1,flag&&i==cnt,true);  
  34.             else  
  35.             {  
  36.                 if(e==0)  
  37.                 {  
  38.                     ans+= dfs(len-1,1,1,flag&&i==cnt,true);  
  39.                 }  
  40.             }  
  41.         }  
  42.         else  
  43.         {  
  44.             if(pre%2==0)  
  45.                 ans+=dfs(len-1,0,e^1,flag&&i==cnt,true);  
  46.             else  
  47.             {  
  48.                 if(e==0)  
  49.                 {  
  50.                     ans+=dfs(len-1,0,0,flag&&i==cnt,true);  
  51.                 }  
  52.             }  
  53.         }  
  54.     }  
  55.     if(!flag&&s)  
  56.         dp[len][pre][e]=ans;  
  57.     return ans;  
  58. }  
  59. long long int solve(long long int x)  
  60. {  
  61.     int len=0;  
  62.     memset(a,0,sizeof(0));  
  63.     while(x>0)  
  64.     {  
  65.         a[len++]=x%10;  
  66.         x/=10;  
  67.     }  
  68.     return dfs(len-1,0,0,true,false);  
  69. }  
  70. int main()  
  71. {  
  72.     int t,ca=1;  
  73.     scanf("%d",&t);  
  74.     memset(dp,-1,sizeof(dp));  
  75.     while(t--)  
  76.     {  
  77.         long long int l,r;  
  78.         scanf("%I64d%I64d",&l,&r);  
  79.         printf("Case #%d: %I64d\n",ca++,solve(r)-solve(l-1));  
  80.     }  
  81.     return 0;  
  82. }  
比赛的时候在OB 感谢队友带我飞
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值