2020牛客NOIP赛前集训营-提高组(第三场)C-牛半仙的妹子Tree【虚树,最短路】

正题

题目链接:https://ac.nowcoder.com/acm/contest/7609/C


题目大意

给出nnn个点的一棵树,mmm个时刻各有一个操作

  1. 标记一个点,每个点被标记后的每一个时刻会标记掉周围的点。
  2. 删去所有点的标记
  3. 询问一个点是否有标记

解题思路

考虑没有二操作怎么搞,可以理解为标记代表起点,然后跑一遍最短路求出每个点被标记的最短时间。

如果有二操作的话是不是就很麻烦了,因为它像一个分割符一样切开两段操作。

那么就直接分开操作就好了!对于每段操作的所有点建立虚树,然后跑最短路就好了。

时间复杂度O(nlog⁡n)O(n\log n)O(nlogn),因为是树就用我们的老朋友SPFA\text{SPFA}SPFA就好了

正解是定期重构+SPFA\text{SPFA}SPFA的,懒得写


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define mp(x,y) make_pair(x,y)
using namespace std;
const int N=2e5+10,T=18;
struct node{int to,next,w;
}a[N<<1];
int n,m,cnt,qnt,pnt,tot,top,ls[N];
int dep[N],dfn[N],f[N][T+1],s[N];
int ve[N],dis[N],t[N],p[N];
pair<int,int> q[N];bool v[N];
void addl(int x,int y){a[++tot].to=y;a[tot].next=ls[x];ls[x]=tot;return;
}
void adde(int x,int y){a[++tot].to=y;a[tot].next=ls[x];ls[x]=tot;a[tot].w=dep[y]-dep[x];a[++tot].to=x;a[tot].next=ls[y];ls[y]=tot;a[tot].w=dep[y]-dep[x];ve[++pnt]=x;ve[++pnt]=y;return;
}
void dfs(int x,int fa){dep[x]=dep[fa]+1;dfn[x]=++cnt;for(int i=ls[x];i;i=a[i].next){int y=a[i].to;if(y==fa)continue;f[y][0]=x;dfs(y,x);}return;
}
int LCA(int x,int y){if(dep[x]>dep[y])swap(x,y);for(int i=T;i>=0;i--)if(dep[f[y][i]]>=dep[x])y=f[y][i];if(x==y)return x;for(int i=T;i>=0;i--)if(f[x][i]!=f[y][i])x=f[x][i],y=f[y][i];return f[x][0];
}
bool cmp(int x,int y)
{return dfn[x]<dfn[y];}
void Ins(int x){if(!top){s[++top]=x;return;}int lca=LCA(x,s[top]);while(top>1&&dep[s[top-1]]>dep[lca])adde(s[top-1],s[top]),top--;if(dep[s[top]]>dep[lca])adde(lca,s[top]),top--;if(s[top]!=lca||!top)s[++top]=lca;s[++top]=x;return;
}
void solve(){queue<int> q;sort(ve+1,ve+1+pnt);pnt=unique(ve+1,ve+1+pnt)-ve-1;for(int i=1;i<=pnt;i++){int x=ve[i];if(t[x])q.push(x),v[x]=1,dis[x]=t[x];}while(!q.empty()){int x=q.front();v[x]=0;q.pop();for(int i=ls[x];i;i=a[i].next){int y=a[i].to;if(dis[x]+a[i].w<dis[y]){dis[y]=dis[x]+a[i].w;if(!v[y])q.push(y),v[y]=1;}}}return;
}
int main()
{scanf("%d%d",&n,&m);for(int i=1;i<n;i++){int x,y;scanf("%d%d",&x,&y);addl(x,y);addl(y,x);}dfs(1,1);for(int j=1;j<=T;j++)for(int i=1;i<=n;i++)f[i][j]=f[f[i][j-1]][j-1];cnt=tot=0;m++;memset(ls,0,sizeof(ls));memset(dis,0x3f,sizeof(dis));for(int z=1;z<=m;z++){int op,x;if(z==m)op=2;else scanf("%d%d",&op,&x);if(op==1){if(!t[x])p[++cnt]=x,t[x]=z;}else if(op==3)q[++qnt]=mp(x,z),p[++cnt]=x;else{sort(p+1,p+1+cnt,cmp);cnt=unique(p+1,p+1+cnt)-p-1;if(p[1]!=1)s[++top]=1;for(int i=1;i<=cnt;i++)Ins(p[i]);while(top>1)adde(s[top-1],s[top]),top--;solve();for(int i=1;i<=qnt;i++){if(dis[q[i].first]<=q[i].second)puts("wrxcsd");else puts("orzFsYo");}for(int i=1;i<=cnt;i++){int x=p[i];ls[x]=t[x]=0;dis[x]=1e9;}for(int i=1;i<=pnt;i++){int x=ve[i];ls[x]=t[x]=0;dis[x]=1e9;}cnt=qnt=top=tot=pnt=0;}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319005.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

codeforces773 D. Perishable Roads(思维+最短路)

D. Perishable Roads 题意简述&#xff1a; 一个 nnn 个点的完全图 以 iii 为根节点时 询问 能构造的树的 ∑d(x)\sum d(x)∑d(x) 最小是多少。 d(x)d(x)d(x)&#xff1a; xxx 到根节点边权值最小值 MOONPIE题解 首先有一个显而易见的错误贪心&#xff1a; 不妨假设以root\t…

牛客题霸 两数之和C++题解/答案

牛客题霸 两数之和 C题解/答案 题目描述 给出一个整数数组&#xff0c;请在数组中找出两个加起来等于目标值的数&#xff0c; 你给出的函数twoSum 需要返回这两个数字的下标&#xff08;index1&#xff0c;index2&#xff09;&#xff0c;需要满足 index1 小于index2.。注意&…

P3244-[HNOI2015]落忆枫音【dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3244 题目大意 给出一个DAG\text{DAG}DAG&#xff0c;保证111可以到达所有点。然后再加入一条边&#xff08;之后不一定是DAG\text{DAG}DAG&#xff09;。 求有多少棵以111为根的外向生成树。 1≤n≤105,1≤m≤21051\leq n…

EF Core 实现多租户

SAAS 和多租户SaaS(软件及服务)区别于其他应用程序的主要特征就是能够使客户在使用应用程序时按照使用量付费。他们不需要为软件购买许可&#xff0c;也不需要安装、托管和管理它。这方面的操作全部由提供 SaaS 软件的组织负责。多租户是实现 SaaS 的关键因素, 它可以让多个企业…

P3246 [HNOI2016]序列(莫队+单调栈+ST表)

[HNOI2016]序列 Tea神题解 Kelin神题解 对于莫队算法最主要的是如何快速算出[l,r]→[l,r1][l,r]\to[l,r1][l,r]→[l,r1]对答案的贡献的变化。 当询问区间发生上述变化时[l,r]→[l,r1][l,r]\to [l,r1][l,r]→[l,r1]不难发现子区间增加这些&#xff1a;[l,r1],[l1,r1],…,[r,r1…

P6672-[清华集训2016]你的生命已如风中残烛【结论】

正题 题目链接:https://www.luogu.com.cn/problem/P6672 题目大意 长度为mmm的序列aaa&#xff0c;有nnn个数字不是000&#xff0c;其他m−nm-nm−n个是000。要求重排后有多少方案满足 ∀x,∑i1xai≥i\forall x,\sum_{i1}^xa_i\geq i∀x,i1∑x​ai​≥i 其中m∑i1naim\sum_{i…

牛客题霸 反转链表 C++题解/答案

题目描述 输入一个链表&#xff0c;反转链表后&#xff0c;输出新链表的表头。 示例1 输入 复制 {1,2,3} 返回值 复制 {3,2,1} 题解&#xff1a; 如果用偷懒的方法&#xff0c;可以用vector来存链表内容&#xff0c;然后来个翻转&#xff08;vector自带&#xff09;即可 但是…

【.NET Core项目实战-统一认证平台】第五章 网关篇-自定义缓存Redis

上篇文章【.NET Core项目实战-统一认证平台】第四章 网关篇-数据库存储配置&#xff08;2&#xff09;我们介绍了2种网关配置信息更新的方法和扩展Mysql存储&#xff0c;本篇我们将介绍如何使用Redis来实现网关的所有缓存功能&#xff0c;用到的文档及源码将会在GitHub上开源&a…

P5934-[清华集训2012]最小生成树【最小割】

正题 题目链接:https://www.luogu.com.cn/problem/P5934 题目大意 给出nnn个点mmm条边的一张图&#xff0c;再加入一条边(u,v,L)(u,v,L)(u,v,L)求至少删掉多少条边可以使得这条边即在最小生成树上又在最大生成树上。 1≤n≤2104,1≤m≤21051\leq n\leq 2\times 10^4,1\leq m\…

广州.net俱乐部12月份ABP框架活动场地征集、志愿者征集、合作讲师\副讲师征集...

大家好&#xff0c;我在<被低估的.net(上) - 微软MonkeyFest 2018广州分享会活动回顾>一文中提到&#xff0c;我将在12月份搞一场ABP框架活动&#xff0c;现向大家征集活动场地、志愿者、合作讲师\副讲师。活动课程标题是&#xff1a;如何用ABP框架快速完成项目这是内容大…

4152. [AMPPZ2014]The Captain(稠密图最短路)

4152. [AMPPZ2014]The Captain 显然稠密图的边数时n2n^2n2量级&#xff0c;我们不可能把所有边建立出来&#xff0c;这时候通常寻求一些性质详细见【论题选编】稠密图最短路 针对本题我们可以先这样考虑&#xff0c;假设每个点有且只有一维信息&#xff0c;那么任意两点之间的…

牛客题霸 二分查找 C++题解/答案

牛客题霸 二分查找 C题解/答案 题目描述 请实现有重复数字的有序数组的二分查找。 输出在数组中第一个大于等于查找值的位置&#xff0c;如果数组中不存在这样的数&#xff0c;则输出数组长度加一。 示例1 输入 复制 5,4,[1,2,4,4,5] 返回值 复制 3 题解&#xff1a; 二分模…

CF1446F-Line Distance【计算几何,树状数组,二分】

正题 题目链接:https://www.luogu.com.cn/problem/CF1446F 题目大意 给出nnn个点&#xff0c;求所有点对构成的直线中与原点距离第kkk小的距离 2≤n≤105,1≤k≤n(n−1)22\leq n\leq 10^5,1\leq k\leq \frac{n(n-1)}{2}2≤n≤105,1≤k≤2n(n−1)​ 解题思路 二分还是挺显然的…

牛客题霸 判断链表中是否有环 C++题解/答案

牛客题霸 判断链表中是否有环 C题解/答案 题目描述 判断给定的链表中是否有环 扩展&#xff1a; 你能给出空间复杂度的解法么&#xff1f; 题解&#xff1a; 在这介绍一个简便的方法&#xff1a;快慢指针 就是&#xff1a;一个指针走两步&#xff0c;一个指针走一步 快慢指…

为什么是容器,Docker和Kubernetes?

如果你是一名IT行业的从业者&#xff0c;还没有听说过以上3个词的任何一个&#xff0c;抱歉&#xff0c;你可以改行了&#xff1b;如果你是一名技术人员&#xff0c;无论你是程序员&#xff0c;测试人员&#xff0c;运维工程师还是时髦的DevOps工程师&#xff0c;你还没有运行过…

P2685 [TJOI2012]桥(最短路+线段树)

P2685 [TJOI2012]桥 xcxcli题解 下面思路仿照上述题解&#xff0c;代码基本照抄上述题解 u⇝vu\leadsto vu⇝v表示uuu到vvv的最短路 u→vu\to vu→v表示uuu和vvv直接相连的边 d1ud1_ud1u​表示1⇝u1\leadsto u1⇝u的最短路 dnudn_udnu​表示n⇝vn\leadsto vn⇝v的最短路 题意化…

牛客题霸 [斐波那契数列] C++题解/答

斐波那契数列 题目描述 大家都知道斐波那契数列&#xff0c;现在要求输入一个整数n&#xff0c;请你输出斐波那契数列的第n项&#xff08;从0开始&#xff0c;第0项为0&#xff0c;第1项是1&#xff09;。 n<39 题解&#xff1a; 斐波那契数列。。递推的基础题目 众所周…

一份来自28岁.NET老程序员的自白

写在前面很幸运&#xff0c;28岁的我头发还没有掉光&#xff0c;更幸运的是28岁的我开始了博客园的写作生活&#xff01;这样的技术分享经历让我拓展了自己的朋友圈&#xff01;有幸结识了像张善友张队&#xff08;连续13年的微软MVP&#xff09;&#xff0c;大石头(NewLife团队…

P5825-排列计数【EGF,NTT】

正题 题目链接:https://www.luogu.com.cn/problem/P5825 题目大意 对于每个kkk&#xff0c;求有多少个长度为nnn的排列有kkk个位置上升。 1≤n≤21051\leq n\leq 2\times 10^51≤n≤2105 解题思路 考虑到同时考虑大于和小于十分麻烦&#xff0c;设fif_ifi​表示钦定iii个上升…

牛客题霸 [数组中出现次数超过一半的数字] C++题解/答案

牛客题霸 [数组中出现次数超过一半的数字] C题解/答案 题解&#xff1a; 题意很明确 跑一遍for循环&#xff0c;统计每个数出现的大小 然后再跑一边循环&#xff0c;查看是否存在大于一半的情况 注意题目要求是大于&#xff0c;没有等于 代码&#xff1a; class Solution {…