社区讨论

求调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 条回复,欢迎继续交流。

正在加载回复...