社区讨论
求调awa
P6218[USACO06NOV] Round Numbers S参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @luo19j4z
- 此快照首次捕获于
- 2024/04/06 19:50 2 年前
- 此快照最后确认于
- 2024/04/06 21:20 2 年前
70分,wa后3点
CPP#include<bits/stdc++.h>
using namespace std;
long long dp[50][50],lon,a[50],l,r;
int dfs(int pos,bool lim,int lead,int cha)
{
short temp=0;
if(pos==0) return cha>=0;
if(!lim&&!lead&&dp[pos][cha]!=-1) return dp[pos][cha];
long long res=0,up=lim?a[pos]:1;
for(int i=0;i<=up;i++){
if(i==0)
{
if(lead) temp=0;
else temp=1;
}
else temp=-1;
res+=dfs(pos-1,lim&(i==a[pos]),lead&(i==0),cha+temp);
}
if(!lim&&!lead) dp[pos][cha]=res;
return res;
}
int work(int u)
{
lon=0;
while(u) a[++lon]=u%2,u/=2;
memset(dp,-1,sizeof(dp));
return dfs(lon,1,1,0);
}
int main()
{
cin>>l>>r;
cout<<work(r)-work(l-1);
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...