日常:论我的T3是如何苟掉的
说起来都是泪啊
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是如何苟掉的的更多相关文章
- NOI前训练日记
向别人学习一波,记点流水帐.17.5.29开坑. 5.29 早晨看了道据说是树状数组优化DP的题(hdu5542),然后脑补了一个复杂度500^3的meet in the middle.然后死T... ...
- 雅礼集训1-9day爆零记
雅礼集训1-9day爆零记 先膜一下虐爆我的JEFF巨佬 Day0 我也不知道我要去干嘛,就不想搞文化科 (文化太辣鸡了.jpg) 听李总说可以去看(羡慕)各路大佬谈笑风声,我就报一个名吧,没想到还真 ...
- Glide Golang包管理
Golang的包管理乱得不行,各种工具横空出世,各显神通啊.用了几个下来,发现 Glide 是比较好用的,使用了 vender 来进行管理,多个开发环境的版本不冲突,功能强大,配置文件也足够简单. 初 ...
- FJOI2019全记录(福建省选)
Day 0 最后一个早上,早读完后就到机房里,复习了左偏树和计算几何,然后真的不知道还要做什么了(FFT和一些数论的结论昨天复习过了 也许还要去学一点新东西(?),像Krusk重构树什么的.(一直没有 ...
- iPhone换电池是原装电池好还是换第三方大容量电池好?
转:https://www.xianjichina.com/news/details_60791.html 最近这段时间苹果降速门事件持续发酵,闹得满城风雨.尽管苹果公司两次致歉,很多果粉都去更换电池 ...
- Google工作法
本文转自:https://www.yuque.com/heqingbao/msfy2c/zg56gm 这几天去上海参加Google开发者大会,利用空闲时间读了一本快餐书,书名叫<Google工作 ...
- 0927CSP-S模拟测试赛后总结
84pts rank28 经历了一个阶段的持续低迷,终于回到自己之前的位置了啊. 尽管依旧不是太靠上,但是还是证明了我的努力. 宿舍三人的风水轮流转之谈终究只是戏言和巧合.嘟嘟和Lockey都进第一机 ...
- [Go疑难杂症]为什么nil不等于nil
现象 在日常开发中,可能一不小心就会掉进 Go 语言的某些陷阱里,而本文要介绍的 nil ≠ nil 问题,便是其中一个,初看起来会让人觉得很诡异,摸不着头脑. 先来看个例子: type Custom ...
- [日常] NOIWC 2018爆零记
开个坑慢慢更(逃 (然而没准会坑掉?) day 0 大概 $8:30$ 就滚去雅礼了qwq 过去的时候发现并没有人...进报到处楼门的时候还被强行拍照围观了一波OwO 然后就领了HZ所有人的提包和狗牌 ...
随机推荐
- 2.27 MapReduce Shuffle过程如何在Job中进行设置
一.shuffle过程 总的来说: *分区 partitioner *排序 sort *copy (用户无法干涉) 拷贝 *分组 group 可设置 *压缩 compress *combiner ma ...
- [技术分享]利用MSBuild制作msf免杀的后门
文章github上有公开现成的shellcode,这就是shellcode 我这次选择了32位的那个版本来进行演示 需要改写的是shellcode那部分: 选择CobaltStrike:payload ...
- JDK8 Lamdba表达式转换成Map,value为null问题
// 将list转换成Map类型 Map<String, String> map = list.stream().collect(Collectors.toMap(Person::getI ...
- 洛谷 - P2774 - 方格取数问题 - 二分图最大独立点集 - 最小割
https://www.luogu.org/problemnew/show/P2774 把两个相邻的节点连边,这些边就是要方便最小割割断其他边存在的,容量无穷. 这种类似的问题的话,把二分图的一部分( ...
- (水题)洛谷 - P1478 - 陶陶摘苹果(升级版)
https://www.luogu.org/problemnew/show/P1478 没啥好说的…… 居然还漏写一个等于号WA了一发. #include<bits/stdc++.h> u ...
- tarjan有向图的强连通
强连通:在有向图G中,两个顶点间至少存在一条路径,则两个点强连通. 强连通图:在有向图中,每两个顶点都强连通,则有向图G就是一个强连通图. 强连通分量:在非强连通图中的极大强连通子图,就称为强连通分量 ...
- python之unittest
unittest是单元测试的一个框架 在说unittest之前,先说几个概念: TestCase 也就是测试用例 TestSuite 多个测试用例集合在一起,就是TestSuite TestLoade ...
- Codeforces Round #544 (Div. 3) D. Zero Quantity Maximization
链接:https://codeforces.com/contest/1133/problem/D 题意: 给两个数组a,b. 同时ci = ai * d + bi. 找到一个d使c数组中的0最多. 求 ...
- Linux Ubuntu 14.04 LTS下VirtualBox连接USB
1.环境 主机:Ubuntu 14.04 LTS 虚拟机:Windows 7 专业版本 VirtualBox: 图形用户界面版本 5.1.8 r111374 (Qt5.6.1) 2.在主机上给Virt ...
- mvc报( 检测到有潜在危险的 request.form 值 )错的解决方案
今天在做项目中遇到了报( 检测到有潜在危险的 request.form 值 )错,百度过后解决了该问题,出此问题主要还是因为提交的Form中有HTML字符串,例如你在TextBox中输入了html标签 ...