LINK:战略游戏

一道很有价值的题目。这道题 一张无向联通图 每次询问给出K个关键点 问摧毁图中哪个点可以使得这K个关键的两两之间有一对不能联通 去掉的这个点不能是关键点 求方案数。

可以发现 当K==2的时候 我们从一个点到另外一个点 能摧毁的必然是关键点 一张无向联通图 如果是关键点的话 那么必然不存在另外一条路径 所以这个关键点符合割点的定义 我们只需要求出路径上有多少个割点即可。

考虑 K个点怎么做 可以发现建出圆方树 这样两点之间的割点数量就是圆方树上圆点数量。那么我们只要建出虚树按边来统计答案即可。

更简便的是我们K个点按dfs序排序后 两两之间的路径形成了整体的两倍。不需要建虚树直接计算即可。

考虑这是点权 并非边权 所以我们把点权放到边权上 显然是放到父亲的那个边上。这样统计下来可以发现只有最上方的公共LCA没有被统计到 加上即可。

最上方LCA 显然是深度最浅的所以我们可以比大小得出 更简便的是 考虑dfs序 可以发现 LCA为第一个点和最后一个点的LCA。

坑点:多组数据 清空一定要清空好 多测不清空 爆零两行泪。我就是以为自己清空了 结果没清空干净导致GG 调了2h硬是没看出来哪错了。

我的倍增数组f 没有清空我以为不用清空其实是需要的 在倍增的时候可能有上次的信息 导致找不到LCA 这点值得特殊注意。

const int MAXN=200010;
int T,n,Q,m,len,cnt,id,top,sum;
int dfn[MAXN],f[MAXN][20],Log[MAXN],low[MAXN],d[MAXN],s[MAXN];
int lin[MAXN],ver[MAXN<<1],nex[MAXN<<1],v[MAXN],a[MAXN];
vector<int>g[MAXN];
inline void cle()
{
id=top=len=cnt=0;
rep(1,200000,i)lin[i]=0,g[i].clear(),dfn[i]=0,v[i]=0,low[i]=0;
}
inline int cmp(int a,int b){return dfn[a]<=dfn[b];}
inline void add(int x,int y)
{
ver[++len]=y;
nex[len]=lin[x];
lin[x]=len;
}
inline void dfs(int x)//构建圆方树
{
dfn[x]=low[x]=++cnt;
s[++top]=x;
for(int i=lin[x];i;i=nex[i])
{
int tn=ver[i];
if(!dfn[tn])
{
dfs(tn);
low[x]=min(low[x],low[tn]);
if(dfn[x]==low[tn])//x为近似割点
{
++id;
for(int j=0;j!=tn;--top)
{
j=s[top];
g[id].pb(j);
}
g[x].pb(id);
}
}
else low[x]=min(low[x],dfn[tn]);
}
}
inline int LCA(int x,int y)
{
if(d[x]<d[y])swap(x,y);
for(int i=Log[d[x]];i>=0;--i)
if(d[f[x][i]]>=d[y])x=f[x][i];
if(x==y)return x;
for(int i=Log[d[x]];i>=0;--i)
if(f[x][i]!=f[y][i])x=f[x][i],y=f[y][i];
return f[x][0];
}
inline void dp(int x,int fa)
{
d[x]=d[fa]+1;dfn[x]=++cnt;
//if(T==0){++sum;cout<<d[x]<<' '<<sum<<endl;}
v[x]=v[fa]+(x<=n);f[x][0]=fa;
rep(1,19,i)f[x][i]=f[f[x][i-1]][i-1];
if(!g[x].size())return;
rep(0,g[x].size()-1,i)
{
int tn=g[x][i];
dp(tn,x);
}
}
int main()
{
freopen("1.in","r",stdin);
get(T);
rep(2,200000,i)Log[i]=Log[i>>1]+1;
while(T--)
{
get(n);get(m);
cle();id=n;
rep(1,m,i)
{
int x,y;
get(x);get(y);
add(x,y);add(y,x);
}
dfs(1);
cnt=0;//put(id);
dp(1,0);
get(Q);
//rep(1,id,i)put(v[i]);
//if(top!=1){puts("ww");return 0;}
rep(1,Q,i)
{
int x;get(x);
rep(1,x,j)get(a[j]);
sort(a+1,a+1+x,cmp);
int ans=0;a[x+1]=a[1];
int minn=INF,p=0;
rep(1,x,j)
{
int lca=LCA(a[j],a[j+1]);
if(d[lca]<minn)minn=d[lca],p=lca;
ans+=v[a[j]]+v[a[j+1]]-v[lca]*2;
}
//put(ans);
ans+=(p<=n)*2;
ans=ans>>1;ans-=x;
put(ans);
}
}
return 0;
}

luogu P4606 [SDOI2018]战略游戏的更多相关文章

  1. Luogu P4606 [SDOI2018] 战略游戏 圆方树 虚树

    https://www.luogu.org/problemnew/show/P4606 把原来的图的点双联通分量缩点(每个双联通分量建一个点,每个割点再建一个点)(用符合逻辑的方式)建一棵树(我最开始 ...

  2. [bzoj5329] P4606 [SDOI2018]战略游戏

    P4606 [SDOI2018]战略游戏:广义圆方树 其实会了圆方树就不难,达不到黑,最多算个紫 那个转换到圆方树上以后的处理方法,画画图就能看出来,所以做图论题一定要多画图,并把图画清楚点啊!! 但 ...

  3. 洛谷P4606 [SDOI2018]战略游戏 【圆方树 + 虚树】

    题目链接 洛谷P4606 双倍经验:弱化版 题解 两点之间必经的点就是圆方树上两点之间的圆点 所以只需建出圆方树 每次询问建出虚树,统计一下虚树边上有多少圆点即可 还要讨论一下经不经过根\(1\)的情 ...

  4. 洛谷P4606 [SDOI2018]战略游戏 [广义圆方树]

    传送门 思路 先考虑两点如何使他们不连通. 显然路径上所有的割点都满足条件. 多个点呢?也是这样的. 于是可以想到圆方树.一个点集的答案就是它的虚树里圆点个数减去点集大小. 可以把点按dfs序排序,然 ...

  5. bzoj5315/luoguP4517 [SDOI2018]战略游戏(圆方树,虚树)

    bzoj5315/luoguP4517 [SDOI2018]战略游戏(圆方树,虚树) bzoj Luogu 题目描述略(太长了) 题解时间 切掉一个点,连通性变化. 上圆方树. $ \sum |S| ...

  6. [SDOI2018]战略游戏 圆方树,树链剖分

    [SDOI2018]战略游戏 这题是道路相遇(题解)的升级版,询问的两个点变成了\(S\)个点. LG传送门 还是先建出圆方树,考虑对于询问的\(S\)个点,答案就是圆方树上能包含这些点的最小连通块中 ...

  7. BZOJ5329: [SDOI2018]战略游戏——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5329 https://www.luogu.org/problemnew/show/P4606 省选 ...

  8. [BZOJ5329][SDOI2018]战略游戏

    bzoj luogu Description 省选临近,放飞自我的小Q无心刷题,于是怂恿小C和他一起颓废,玩起了一款战略游戏. 这款战略游戏的地图由n个城市以及m条连接这些城市的双向道路构成,并且从任 ...

  9. BZOJ5329:[SDOI2018]战略游戏(圆方树,虚树)

    Description 省选临近,放飞自我的小Q无心刷题,于是怂恿小C和他一起颓废,玩起了一款战略游戏. 这款战略游戏的地图由n个城市以及m条连接这些城市的双向道路构成,并且从任意一个城市出发总能沿着 ...

随机推荐

  1. 转载--未看关于移动端Web远程开发调试

    移动端Web开发调试之Chrome远程调试(Remote Debugging) http://blog.csdn.net/freshlover/article/details/42528643 移动端 ...

  2. 洛谷 P2882 [USACO07MAR]Face The Right Way G

    题目传送门 题目描述 Farmer John has arranged his N (1 ≤ N ≤ 5,000) cows in a row and many of them are facing ...

  3. Python-模块XlsxWriter将数据写入excel

    1.目的 用xlwt来生成excel的,生成的后缀名为xls,在xlwt中生成的xls文件最多能支持65536行数据.python XlsxWriter模块创建aexcel表格,生成的文件后缀名为.x ...

  4. 顺时针打印矩阵(剑指offer-19)

    题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数 ...

  5. HotSpot的类模型(4)

    我们继续接着上一篇 HotSpot的类模型(3)分析,这次主要分析表示java数组的C++类. 4.ArrayKlass类 ArrayKlass继承自Klass,是所有数组类的抽象基类,类及重要属性的 ...

  6. 百万级别数据Excel导出优化

    前提 这篇文章不是标题党,下文会通过一个仿真例子分析如何优化百万级别数据Excel导出. 笔者负责维护的一个数据查询和数据导出服务是一个相对远古的单点应用,在上一次云迁移之后扩展为双节点部署,但是发现 ...

  7. 数据可视化之powerBI技巧(二十三)Power BI可视化技巧,使用DAX自定义时间轴

    ​按照自然日历来展现疫情数据时,是这样的效果, 由于各个国家的疫情爆发时间不一致,按自然日期坐标轴很难比较各个国家的蔓延速度. 如果各个国家都从蔓延日开始统计,展示之后每日的确诊人数,就是同样的时间轴 ...

  8. unity-TextAsset

    定义: 当把Text files导到unity,将会变成TextAsset. 支持的格式: .txt .html .htm .xml .bytes .json .csv .yaml .fnt 注意 不 ...

  9. bzoj3289Mato的文件管理

    bzoj3289Mato的文件管理 题意: 一共有n份资料,每天随机选一个区间[l,r],Mato按文件从小到大的顺序看编号在此区间内的这些资料.他先把要看的文件按编号顺序依次拷贝出来,再用排序程序给 ...

  10. 【Nginx】面试官问我Nginx能不能配置WebSocket?我给他现场演示了一番!!

    写在前面 当今互联网领域,不管是APP还是H5,不管是微信端还是小程序,只要是一款像样点的产品,为了增加用户的交互感和用户粘度,多多少少都会涉及到聊天功能.而对于Web端与H5来说,实现聊天最简单的就 ...