社区讨论

关于点分治的一点疑问

P4149[IOI 2011] Race参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lo7sukfh
此快照首次捕获于
2023/10/27 07:12
2 年前
此快照最后确认于
2023/10/27 07:12
2 年前
查看原帖
CPP

inline void solve(int x){
	int p=0;
	for(int i=0;i<e[x].size();i++){
		int y=e[x][i].v,w=e[x][i].w;
		if(!vis[y]){
			cnts=0,dis[y]=w;
			getdis(y,0,1);
			for(int j=1;j<=cnts;j++){
				if(m>=a[j].dis)ans=min(ans,visp[m-a[j].dis]+a[j].cnt);
			}
			for(int j=1;j<=cnts;j++){
				tmp[++p]={a[j].dis,visp[a[j].dis]};
				visp[a[j].dis]=min(visp[a[j].dis],a[j].cnt);
			}
		}
	}
	for(int i=1;i<=p;i++){
		visp[tmp[i].dis]=inf;
	}
}
在处理经过点 xx 的路径时,逐个遍历了 xx 子树中的点,并把可能的路径长度存到了 visp 数组中。
问题是,如果把最底下的 visp 的还原改成:
CPP
	for(int i=1;i<=p;i++){
		visp[tmp[i].dis]=tmp[i].cnt;//还原成原来的值
	}

为什么就会 RE + WA 70pts ?
萌新刚学点分治,求助

回复

0 条回复,欢迎继续交流。

正在加载回复...