说起来都是泪啊

T3的bfs一直不对,我想死。

考试时候苟了两个小时,死活找不到错误(因为lca和离散化都码出来了,太乱)

最后把bfs单独提出来,发现在bfs里面输出的f[ly][0]都是正确的,到外面就彻底崩掉,全是0。

又调了一节课,终于发现

数组越界了。。。

错误代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<queue>
#define rint register int
using namespace std;
int n,m,a,b,tot,first[100005];
int deep[100005],f[100005][18];
struct node{
	int u,v,nxt;
}edge[100005];
inline void add(int u,int v)
{
	++tot;
	edge[tot].u=u;
	edge[tot].v=v;
	edge[tot].nxt=first[u];
	first[u]=tot;
}
inline void bfss()
{
	queue <int> q;
	deep[1]=1;
	q.push(1);
	while(!q.empty())
	{
		int lq=q.front();q.pop();
		for(rint i=first[lq];i;i=edge[i].nxt)
		{
			int ly=edge[i].v;
			if(ly==0)continue;
			if(deep[ly])continue;
			deep[ly]=deep[lq]+1;
			f[ly][0]=lq;
			cout<<ly<<":fa:"<<f[ly][0]<<endl;
//			cout<<f[20][0]<<endl;
			for(rint j=1;j<=18;++j)
			{
				f[ly][j]=f[f[ly][j-1]][j-1];
				printf("f[%d][%d]=%d\n",ly,j,f[ly][j]);
			}
			q.push(ly);
		}
	}
	return ;
}
int main()
{
	scanf("%d %d",&n,&m);
	for(rint i=1;i<n;++i)
	{
		scanf("%d %d",&a,&b);
		add(a,b);add(b,a);
	}
	bfss();
	cout<<f[20][0]<<endl;
}

正确代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<queue>
#define rint register int
using namespace std;
int n,m,a,b,tot,first[100005];
int deep[100005],f[100005][18];
struct node{
	int u,v,nxt;
}edge[100005];
inline void add(int u,int v)
{
	++tot;
	edge[tot].u=u;
	edge[tot].v=v;
	edge[tot].nxt=first[u];
	first[u]=tot;
}
inline void bfss()
{
	queue <int> q;
	deep[1]=1;
	q.push(1);
	while(!q.empty())
	{
		int lq=q.front();q.pop();
		for(rint i=first[lq];i;i=edge[i].nxt)
		{
			int ly=edge[i].v;
			if(ly==0)continue;
			if(deep[ly])continue;
			deep[ly]=deep[lq]+1;
			f[ly][0]=lq;
			cout<<ly<<":fa:"<<f[ly][0]<<endl;
//			cout<<f[20][0]<<endl;
			for(rint j=1;j<=17;++j)
			{
				f[ly][j]=f[f[ly][j-1]][j-1];
				printf("f[%d][%d]=%d\n",ly,j,f[ly][j]);
			}
			q.push(ly);
		}
	}
	return ;
}
int main()
{
	scanf("%d %d",&n,&m);
	for(rint i=1;i<n;++i)
	{
		scanf("%d %d",&a,&b);
		add(a,b);add(b,a);
	}
	bfss();
	cout<<f[20][0]<<endl;
}

我想去死怎么办。。。

日常:论我的T3是如何苟掉的的更多相关文章

  1. NOI前训练日记

    向别人学习一波,记点流水帐.17.5.29开坑. 5.29 早晨看了道据说是树状数组优化DP的题(hdu5542),然后脑补了一个复杂度500^3的meet in the middle.然后死T... ...

  2. 雅礼集训1-9day爆零记

    雅礼集训1-9day爆零记 先膜一下虐爆我的JEFF巨佬 Day0 我也不知道我要去干嘛,就不想搞文化科 (文化太辣鸡了.jpg) 听李总说可以去看(羡慕)各路大佬谈笑风声,我就报一个名吧,没想到还真 ...

  3. Glide Golang包管理

    Golang的包管理乱得不行,各种工具横空出世,各显神通啊.用了几个下来,发现 Glide 是比较好用的,使用了 vender 来进行管理,多个开发环境的版本不冲突,功能强大,配置文件也足够简单. 初 ...

  4. FJOI2019全记录(福建省选)

    Day 0 最后一个早上,早读完后就到机房里,复习了左偏树和计算几何,然后真的不知道还要做什么了(FFT和一些数论的结论昨天复习过了 也许还要去学一点新东西(?),像Krusk重构树什么的.(一直没有 ...

  5. iPhone换电池是原装电池好还是换第三方大容量电池好?

    转:https://www.xianjichina.com/news/details_60791.html 最近这段时间苹果降速门事件持续发酵,闹得满城风雨.尽管苹果公司两次致歉,很多果粉都去更换电池 ...

  6. Google工作法

    本文转自:https://www.yuque.com/heqingbao/msfy2c/zg56gm 这几天去上海参加Google开发者大会,利用空闲时间读了一本快餐书,书名叫<Google工作 ...

  7. 0927CSP-S模拟测试赛后总结

    84pts rank28 经历了一个阶段的持续低迷,终于回到自己之前的位置了啊. 尽管依旧不是太靠上,但是还是证明了我的努力. 宿舍三人的风水轮流转之谈终究只是戏言和巧合.嘟嘟和Lockey都进第一机 ...

  8. [Go疑难杂症]为什么nil不等于nil

    现象 在日常开发中,可能一不小心就会掉进 Go 语言的某些陷阱里,而本文要介绍的 nil ≠ nil 问题,便是其中一个,初看起来会让人觉得很诡异,摸不着头脑. 先来看个例子: type Custom ...

  9. [日常] NOIWC 2018爆零记

    开个坑慢慢更(逃 (然而没准会坑掉?) day 0 大概 $8:30$ 就滚去雅礼了qwq 过去的时候发现并没有人...进报到处楼门的时候还被强行拍照围观了一波OwO 然后就领了HZ所有人的提包和狗牌 ...

随机推荐

  1. error the @annotation pointcut expression is only supported at Java 5

    eclipse搭建环境后报错 the pointcut is supported at Java 5 错误意思大致是:注释切入点表达式只支持在Java 5版本以上,我就纳闷了我安装的是jdk1.8啊, ...

  2. 图像分类与KNN

    1 图像分类问题 1.1 什么是图像分类 所谓图像分类问题,就是已有固定的分类标签集合,然后对于输入的图像,从分类标签集合中找出一个分类标签,最后把分类标签分配给该输入图像.虽然看起来挺简单的,但这可 ...

  3. css里关于浏览器的前缀

    今天遇到一个比较坑爹的 -moz-box-sizing: border-box; box-sizing' border-box;   一下子有点懵逼,第一个什么鬼??一查,原来是火狐浏览器的前缀.应该 ...

  4. c# KeyDown KeyPress 函数中event 的 Handled属性

    很奇怪的 KeyDown中的 Handled.true 只能使 Keys.Back 这类失效, 如果要使比如数字失效,必须设置一个变量 _bHandled = true 然后在紧接着会触发的 KeyP ...

  5. 7天学完Java基础之6/7

    final关键字的概念与四种用法 final关键字代表最终,不可改变的 常见四种用法: 可以用来修饰一个类 当前这个类不能有任何子类 可以用来修饰一个方法 当final关键字用来修饰一个方法的时候,这 ...

  6. 第三篇 .NET高级技术之深拷贝和浅拷贝

    深拷贝.浅拷贝 如果拷贝的时候共享被引用的对象就是浅拷贝,如果被引用的对象也拷贝一份出来就是深拷贝.(深拷贝就是说重新new一个对象,然后把之前的那个对象的属性值在重新赋值给这个用户) using S ...

  7. 本周学习总结(ng-zorro/MDN索引/读书笔记)

    按钮 <button ng-button nzType="primary">Primary</button> nzType="" pri ...

  8. oatu2.0认证原理(转)

    今天有时间总结一下: 一.OAuth是一个关于授权(authorization)的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版. 在详细讲解OAuth 2.0之前,需要了解几个专用名词,理 ...

  9. Opencv读写文件

    HSV也是用和RGB差不多的方式来表达像素,每个整形(integer) 向量分别表示一个B,G,R通道,其他的色彩空间,也用同样的方式来表示像素,只是取值范围和通道数目不同HSV的色彩空间的色度值范围 ...

  10. 使用Git分布式版本控制系统

    GIT(分布式版本控制系统) Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目.   Git是一个开源的分布式版本控制系统,可以有效.高速的处理从很小到非常大的项目版本 ...