【BZOJ】【1662】/【POJ】【3252】 【USACO 2006 Nov】Round Number

时间:2023-12-21 16:06:56

数位DP


同上一题Windy数

预处理求个组合数

然后同样的方法,这次是记录一下0和1的个数然后搞搞

Orz cxlove

 /**************************************************************
Problem: 1662
User: Tunix
Language: C++
Result: Accepted
Time:0 ms
Memory:1280 kb
****************************************************************/ //POJ 3252 && BZOJ 1662
#include<cmath>
#include<vector>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
#define pb push_back
using namespace std;
int getint(){
int v=,sign=; char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') sign=-; ch=getchar();}
while(isdigit(ch)) {v=v*+ch-''; ch=getchar();}
return v*sign;
}
const int N=1e7+,INF=~0u>>;
const double eps=1e-;
/*******************template********************/
int c[][];
void init(){
c[][]=;
F(i,,){
c[i][]=c[i-][];
F(j,,i) c[i][j]=c[i-][j]+c[i-][j-];
}
}
int solve(int n){
int len=,bit[],cnt=;
for(;n;n>>=) bit[++len]=n&;
int ans=;
F(i,,len-)
D(j,i-,(i+)>>)
ans+=c[i-][j];
int one=,zero=;
D(i,len-,)
if (bit[i]){
zero++;
F(j,max(,(len+)/-zero),i-)
ans+=c[i-][j];
zero--;
one++;
}
else zero++;
// ans+=c[cnt-1][(len+1)>>1];
return ans;
}
int main(){
init();
int l=getint(),r=getint();
printf("%d\n",solve(r+)-solve(l));
return ;
}