NOIP 模拟 $38\; \rm c$
题解 \(by\;zj\varphi\)
发现就是一棵树,但每条边都有多种不同的颜色,其实只需要保留随便三种颜色即可。
直接点分治,将询问离线,分成一端为重心,和两端都不为重心的情况。
每次只关心经过重心的询问,其他询问不管,具体实现就是点分治的套路,每次搜一棵子树,更新标记。
动归有些小细节,尽量边权化点权,不容易出错,式子直接看官方题解。
复杂度 \(\mathcal O\rm(3^3nlogn+3^4q)\)
Code
#include<bits/stdc++.h>
#define Re register
#define ri Re signed
#define p(i) ++i
namespace IO{
char buf[1<<21],*p1=buf,*p2=buf;
#define gc() p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?(-1):*p1++
struct nanfeng_stream{
template<typename T>inline nanfeng_stream &operator>>(T &x) {
Re bool f=0;x=0;Re char ch=gc();
while(!isdigit(ch)) f|=ch=='-',ch=gc();
while(isdigit(ch)) x=(x<<1)+(x<<3)+(ch^48),ch=gc();
return x=f?-x:x,*this;
}
}cin;
}
using IO::cin;
namespace nanfeng{
#define node(x,y) (node){x,y}
#define pb emplace_back
#define fi first
#define se second
#define mk std::make_pair
#define FI FILE *IN
#define FO FILE *OUT
template<typename T>inline T cmax(T x, T y) {return x>y?x:y;}
template<typename T>inline T cmin(T x, T y) {return x>y?y:x;}
static const int N=1e5+7;
int first[N],dp[N][4][4],W[N][4],nm[N],tmp[4],G[N],siz[N],ans[N<<2],vis[N],dep,rt,pos,q,cnt,t=1,n,m;
struct node{int v,i;}ask;
std::vector<node> vc[N];
struct edge{int v,nxt,w[4],nm;}e[N<<1];
std::map<std::pair<int,int>,std::set<int> > mp;
inline void add(int u,int v,int *w,int nm) {
e[t].v=v,e[t].nm=nm;
for (ri i(1);i<=nm;p(i)) e[t].w[i]=w[i];
e[t].nxt=first[u],first[u]=t++;
e[t].v=u,e[t].nm=nm;
for (ri i(1);i<=nm;p(i)) e[t].w[i]=w[i];
e[t].nxt=first[v],first[v]=t++;
}
void dfs_find(int S,int x,int fa) {
siz[x]=1;
int GS=0;
for (ri i(first[x]),v;i;i=e[i].nxt) {
if ((v=e[i].v)==fa||G[v]) continue;
dfs_find(S,v,x);
siz[x]+=siz[v];
GS=cmax(GS,siz[v]);
}
GS=cmax(GS,S-siz[x]);
if (GS<cnt) cnt=GS,pos=x;
}
void dfs_solve(int x,int fa) {
siz[x]=1;
for (ri i(first[x]),v;i;i=e[i].nxt) {
if ((v=e[i].v)==fa||G[v]) continue;
for (ri j(1);j<=e[i].nm;p(j)) W[v][j]=e[i].w[j];
nm[v]=e[i].nm;
for (ri l(1);l<=nm[rt];p(l))
for (ri j(1);j<=nm[v];p(j))
for (ri k(1);k<=nm[x];p(k))
if (W[x][k]==W[v][j]) dp[v][l][j]=cmax(dp[v][l][j],dp[x][l][k]);
else dp[v][l][j]=cmax(dp[v][l][j],dp[x][l][k]+1);
dfs_solve(v,x);
siz[x]+=siz[v];
}
}
void dfs_query(int x,int fa) {
for (auto nx:vc[x]) {
if (!vis[nx.v]&&nx.v!=pos) continue;
if (nx.v==pos) {
for (ri i(1);i<=nm[rt];p(i))
for (ri j(1);j<=nm[x];p(j))
ans[nx.i]=cmax(ans[nx.i],dp[x][i][j]);
} else {
for (ri i(1);i<=nm[rt];p(i))
for (ri j(1);j<=nm[vis[nx.v]];p(j))
for (ri k(1);k<=nm[x];p(k))
for (ri l(1);l<=nm[nx.v];p(l)) {
if (W[vis[nx.v]][j]==W[rt][i]) ans[nx.i]=cmax(ans[nx.i],dp[x][i][k]+dp[nx.v][j][l]-1);
else ans[nx.i]=cmax(ans[nx.i],dp[x][i][k]+dp[nx.v][j][l]);
}
}
}
for (ri i(first[x]),v;i;i=e[i].nxt) {
if ((v=e[i].v)==fa||G[v]) continue;
dfs_query(v,x);
}
}
void dfs_mark(int x,int fa) {
vis[x]=rt;
for (ri i(first[x]),v;i;i=e[i].nxt) {
if ((v=e[i].v)==fa||G[v]) continue;
dfs_mark(v,x);
}
}
void dfs_init(int x,int fa) {
vis[x]=0;
memset(dp[x],0,sizeof(dp[x]));
for (ri i(first[x]),v;i;i=e[i].nxt) {
if (G[v=e[i].v]||v==fa) continue;
dfs_init(v,x);
}
}
void solve(int S,int x) {
dfs_find(cnt=S,x,0);
dfs_init(pos,0);
int np;
G[np=pos]=1;
for (ri i(first[np]),v;i;i=e[i].nxt) {
if (G[v=e[i].v]) continue;
for (ri j(1);j<=e[i].nm;p(j)) dp[v][j][j]=1,W[v][j]=e[i].w[j];
nm[v]=e[i].nm;
dfs_solve(rt=v,np);
dfs_query(v,np);
dfs_mark(v,np);
}
dfs_init(pos,0);
for (ri i(first[np]),v;i;i=e[i].nxt) {
if (G[v=e[i].v]) continue;
solve(siz[v],v);
}
}
inline int main() {
//FI=freopen("nanfeng.in","r",stdin);
//FO=freopen("nanfeng.out","w",stdout);
cin >> n >> m;
for (ri i(1),u,v,w;i<=m;p(i)) {
cin >> u >> v >> w;
if (u>v) std::swap(u,v);
mp[mk(u,v)].insert(w);
}
for (auto x:mp) {
ri ct=0;
Re std::pair<int,int> tp=x.fi;
Re std::set<int> tps=x.se;
if (tps.size()>3) for (auto w:tps) {tmp[++ct]=w;if (ct==3) break;}
else for (auto w:tps) tmp[++ct]=w;
add(tp.fi,tp.se,tmp,ct);
}
cin >> q;
for (ri i(1),u,v;i<=q;p(i)) cin >> u >> v,vc[u].pb(node(v,i)),vc[v].pb(node(u,i));
solve(n,1);
for (ri i(1);i<=q;p(i)) printf("%d\n",ans[i]);
return 0;
}
}
int main() {return nanfeng::main();}
NOIP 模拟 $38\; \rm c$的更多相关文章
- NOIP 模拟 $38\; \rm b$
题解 \(by\;zj\varphi\) 考虑转化问题,将计算最大公约数换为枚举最大公约数. 设 \(sum_i\) 为最大公约数为 \(i\) 的方案数,可以容斥求解,\(sum_i=f_i-\su ...
- NOIP 模拟 $38\; \rm a$
题解 \(by\;zj\varphi\) 压行. 枚举两行,将中间的行压成一行,然后直接前缀和加二分. 注意边界细节问题. Code #include<bits/stdc++.h> #de ...
- 2021.5.22 noip模拟1
这场考试考得很烂 连暴力都没打好 只拿了25分,,,,,,,,好好总结 T1序列 A. 序列 题目描述 HZ每周一都要举行升旗仪式,国旗班会站成一整列整齐的向前行进. 郭神作为摄像师想要选取其中一段照 ...
- NOIP模拟3
期望得分:30+90+100=220 实际得分:30+0+10=40 T1智障错误:n*m是n行m列,硬是做成了m行n列 T2智障错误:读入三个数写了两个%d T3智障错误:数值相同不代表是同一个数 ...
- 7.22 NOIP模拟7
又是炸掉的一次考试 T1.方程的解 本次考试最容易骗分的一道题,但是由于T2花的时间太多,我竟然连a+b=c都没判..暴力掉了40分. 首先a+b=c,只有一组解. 然后是a=1,b=1,答案是c-1 ...
- NOIP模拟 1
NOIP模拟1,到现在时间已经比较长了.. 那天是6.14,今天7.18了 //然鹅我看着最前边缺失的模拟1,还是终于忍不住把它补上,为了保持顺序2345重新发布了一遍.. # 用 户 名 ...
- 20190725 NOIP模拟8
今天起来就是虚的一批,然后7.15开始考试,整个前半个小时异常的困,然后一看题,T1一眼就看出了是KMP,但是完了,自己KMP的打法忘的一干二净,然后开始打T2,T2肝了一个tarjan点双就扔上去了 ...
- 20190902+0903合集-NOIP模拟
一直没时间写QwQ 于是补一下. Day 1 晚饭吃的有点恶心…… $1s\,2s\,5s$ 还开 -O2 ?? 有点恐怖. T1 猛的一想: 把外面设成一个点, 向入口连一条权为排队时间的边 从出口 ...
- 5.23考试总结(NOIP模拟2)
5.23考试总结(NOIP模拟2) 洛谷题单 看第一题第一眼,不好打呀;看第一题样例又一眼,诶,我直接一手小阶乘走人 然后就急忙去干T2T3了 后来考完一看,只有\(T1\)骗到了\(15pts\)[ ...
随机推荐
- WPF教程五:附加依赖项属性
附加依赖项属性是一个属性本来不属于对象自己,但是某些特定场景其他的对象要使用该对象在这种场景下的值.这个值只在这个场景下使用.基于这个需求设计出来的属性.这里主要涉及到一个解耦问题.最大的优势是在特定 ...
- MIT6.828 Lab4 Preemptive Multitasking(下)
Lab4 Preemptive Multitasking(下) lab4的第二部分要求我们实现fork的cow.在整个lab的第一部分我们实现了对多cpu的支持和再多系统环境中的切换,但是最后分析的时 ...
- 雪花算法(SnowFlake)Java实现
分布式id生成算法的有很多种,Twitter的SnowFlake就是其中经典的一种. 算法原理 SnowFlake算法生成id的结果是一个64bit大小的整数,它的结构如下图: 1bit,不用,因为二 ...
- Requests方法 -- 关联用例执行
1.参照此篇流程 :Requsts方法 -- Blog流程类进行关联 2.用例接口目录如下: 3.用例代码如下: import requestsimport unittestfrom Request. ...
- 5Java基础整理
1.API:Application programming interface 举例:System类中的 public static void arraycopy(int[] src,int srcP ...
- vue3如何编写挂载DOM的插件
vue3 跟 vue2 相比,多了一个 app 的概念,vue3 项目的创建也变成了 // main.jsimport { createApp } from 'vue' import App from ...
- session及cookie详解(七)
前言 文章说明 在每整理一个技术点的时候,都要清楚,为什么去记录它.是为了工作上项目的需要?还是为了搭建技术基石,为学习更高深的技术做铺垫? 让每一篇文章都不是泛泛而谈,复制粘贴,都有它对自己技术提升 ...
- <题解>[IOI2019]景点划分
题目传送门(luogu) 题目传送门(loj) 这个题对我来说可以算是超出了我的能力范围 被学长拿来教我做构造,构造题真简单,构造题真是人,构造题真能手切... 首先对于本题,必须要知道dfs树这东西 ...
- CUDA学习笔记-1: CUDA编程概览
1.GPU编程模型及基本步骤 cuda程序的基本步骤如下: 在cpu中初始化数据 将输入transfer到GPU中 利用分配好的grid和block启动kernel函数 将计算结果transfer到C ...
- 【SpringCloud技术专题】「原生态Fegin」打开Fegin之RPC技术的开端,你会使用原生态的Fegin吗?(上)
前提介绍 Feign是SpringCloud中服务消费端的调用框架,通常与ribbon,hystrix等组合使用. 由于遗留原因,某些项目中,整个系统并不是SpringCloud项目,甚至不是Spri ...