首页 > 其他 > 详细

poj3252数位dp

时间:2014-08-07 02:59:48      阅读:321      评论:0      收藏:0      [点我收藏+]
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <climits>
#include <string>
#include <iostream>
#include <map>
#include <cstdlib>
#include <list>
#include <set>
#include <queue>
#include <stack>
#include<math.h>
using namespace std;
int dp[55][55][55];
int up[100];
int dfs(int now,int len0,int len1,int flag)
{
    if(now==-1) return len0>=len1;
    if(!flag&&dp[now][len0][len1]!=-1) return dp[now][len0][len1];
    int limit= flag?up[now ]:1 ,ret=0 ;
    for(int i = 0;i <= limit;i++){
        int len00=len0;int len11=len1;
        if(i==0&&len1) len00=len0+1;
        if(i==1) len11=len1+1;
        ret+=dfs(now-1,len00,len11,flag&&i==limit) ;
    }
    if(!flag) dp[now][len0][len1]=ret;
    return ret;
}
int solve(int x)
{
    int len=-1;
    while(x){
        up[++len]=x%2;
        x/=2;
    }
    return dfs(len,0,0,1);
}
int main()
{
    int n, m;
    memset(dp,-1,sizeof(dp));
    while(cin>>n>>m){
        cout<<solve(m) - solve(n-1)<<endl;
    }
    return 0;
}

 

poj3252数位dp,布布扣,bubuko.com

poj3252数位dp

原文:http://www.cnblogs.com/yigexigua/p/3896114.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!