奶盖拌饭 NKOJ8457
- 题意:一个无向图,每次询问给出一条边,问这条边的最大值满足这条边一定在这个图的最小生成树上,如果没有上限输出-1。
- 思路:考场上想过的,将分为两类,(非)树边。
1.亿点性质
- 非树边:加上这条边所构成的环上的边都可能替代它,所以它应该是两点树上路径max-1
- 树边:若树边在非树边两端点的路径上,则该非树边可能更新该树边。而树边应该为所有能更新它的非树边min-1。
2.解法
- 费树边:倍增记录mx
- 树边:路径覆盖并查集(自己取名的qaq),枚举所有非树边,暴力往上跳,更新路径上的树边最小值
??TLE!!肯定不能暴力!
先将非树边按边权从小到大排序,所以一条树边只会被更新一次。中间我们维护一个新的并查集,一条边被更新后直接将边的根指到自己的父亲的根(下次就直接get_fa不会经过该点了,并查集还要路径压缩cj快!)
3.代码:写了半个晚自习:
#include<bits/stdc++.h>
using namespace std;
static char buf[1000000],*p1=buf,*p2=buf,obuf[1000000],*p3=obuf;
#define getchar() p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?EOF:*p1++
#define putchar(x) (p3-obuf<1000000)?(*p3++=x):(fwrite(obuf,p3-obuf,1,stdout),p3=obuf,*p3++=x)
template<typename item>
inline void read(register item &x)
{
x=0;register char c=getchar();
while(c<'0'||c>'9')c=getchar();
while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+(c^48),c=getchar();
}
const int N=1e6+5;
const int M=2e6+5;
struct edge {int x,y,z,used,id;}E[M];
bool cmp(edge u,edge v) {return u.z<v.z;}
int ans[M],n,m,q,dep[N],ecnt,nxt[M],head[N],len[M],mn[M],to[M],fa[N],f[N][21],mx[N][21],inf=0x3f3f3f3f;
void add_edge(int u,int v,int w) {nxt[++ecnt]=head[u];to[ecnt]=v;len[ecnt]=w;head[u]=ecnt;}
int g_fa(int u) {return fa[u]==u?u:fa[u]=g_fa(fa[u]);}
void kruskal() {
sort(E+1,E+1+m,cmp);
for(int i=1;i<=n;i++) fa[i]=i;
for(int i=1,j=1;i<=m&&j<n;i++) {
int u=g_fa(E[i].x),v=g_fa(E[i].y);
if(u!=v) {
fa[u]=v;
add_edge(E[i].x,E[i].y,E[i].z),add_edge(E[i].y,E[i].x,E[i].z);
E[i].z=inf,E[i].used=1;
j++;
}
}
}
void dfs(int u,int fa) {
for(int i=head[u];i;i=nxt[i]) {
int v=to[i];
if(v==fa)continue;
dep[v]=dep[u]+1;
f[v][0]=u,mx[v][0]=len[i];
for(int i=1;i<=19;i++)
f[v][i]=f[f[v][i-1]][i-1],mx[v][i]=max(mx[v][i-1],mx[f[v][i-1]][i-1]);
dfs(v,u);
}
}
int Lca(int u,int v) {
if(dep[u]<dep[v]) swap(u,v);
int k=dep[u]-dep[v],res=0;
for(int i=0;i<=19;i++)if((1<<i)&k) res=max(res,mx[u][i]),u=f[u][i];
if(u==v) return res;
for(int i=19;i>=0;i--) {
if(f[u][i]!=f[v][i]) res=max(res,max(mx[u][i],mx[v][i])),u=f[u][i],v=f[v][i];
}
return max(res,max(mx[u][0],mx[v][0]));
}
void work() {
memset(mn,-1,sizeof(mn));
sort(E+1,E+1+m,cmp);
for(int i=1;i<=n;i++)fa[i]=i;
for(int i=1;i<=m;i++) {
if(E[i].used) continue;
int u=E[i].x,v=E[i].y;
while(u!=v) {
if(dep[u]<dep[v]) swap(u,v);
if(mn[u]==-1)mn[u]=E[i].z;
int r=g_fa(f[u][0]);
fa[u]=r,u=r;
}
}
}
void solve() {
for(int i=1;i<=m;i++) {
int u=E[i].x,v=E[i].y;
if(dep[u]<dep[v]) swap(u,v);
if(E[i].used) {
if(mn[u]==-1) ans[E[i].id]=-1;
else ans[E[i].id]=mn[u]-1;
}
else ans[E[i].id]=Lca(u,v)-1;
}
}
int main() {
read(n),read(m);
for(int i=1;i<=m;i++) read(E[i].x),read(E[i].y),read(E[i].z),E[i].id=i;
kruskal();
dep[1]=1,dfs(1,0);
work();
solve();
read(q);
while(q--) {
int s;
read(s);
printf("%d\n",ans[s]);
}
return 0;
}
ps.还有最近的题全要用fread的快读qwq……
奶盖拌饭 NKOJ8457的更多相关文章
- 本溪6397.7539(薇)xiaojie:本溪哪里有xiaomei
本溪哪里有小姐服务大保健[微信:6397.7539倩儿小妹[本溪叫小姐服务√o服务微信:6397.7539倩儿小妹[本溪叫小姐服务][十微信:6397.7539倩儿小妹][本溪叫小姐包夜服务][十微信 ...
- [nRF51822] 6、基于nRF51822平台的flash读写研究
前言 本文重点介绍flash的数据存取特性.flash的内存划分.一个简单的存取图片的内存管理方式,以及对flash写前删的时间.删后读的时间.写后读的时间进行测量的一个小实验.目的在于更全面了解fl ...
- OCR技术
"起初我写这篇教程是在情人节,OCR可以带给你一整年的爱". 你之前肯定已经见过,OCR技术被应用于在平板电脑上将扫描文件处理成手写字迹,还被应用于谷歌最近添加到他们的Transl ...
- ubuntu1604 golang环境
copy来的,这里记录一下 1. 升级系统: sudo apt-get upgrade 2. 安装docker 下载docker-ce: https://download.docker.com/lin ...
- mq(1):简介
1.mq的使用场景 以前的我,一直都没太搞明白,为什么我们那么需要消息队列,直到我看到了网友scienjus.的这个例子. 例子:假设用户在你的软件中注册,服务端收到用户的注册请求后,它会做这些操作: ...
- .NET环境下使用水晶报表
.NET环境下使用水晶报表 听语音 | 浏览:3280 | 更新:2013-12-20 13:36 1 2 3 4 5 6 7 分步阅读 水晶报表(Crystal Reports)-商务智能软件,通常 ...
- python中的循环和编码,运算符, 格式化输出
1.while循环 现在让我们来看看python中的while循环 格式为 while 条件 循环体 (break) (continue) 中断循环的关键字有break和continue, brea ...
- 我的OI生涯 第四章
第四章 晚上来机房的人越来越多了,我也注意到一个常年独自坐在一个角落的男人————郝哥. 郝哥为人很安静,只是那时我还不知道他好不好,就没有与他交流过什么,这个优秀的男人以后我们还会提到,这里先不讲. ...
- 2018 Spring Single Training B (uva 572,HihoCoder 1632,POJ 2387,POJ 2236,UVA 10054,HDU 2141)
这场比赛可以说是灰常的水了,涨信心场?? 今下午义务劳动,去拿着锄头发了将近一小时呆,发现自己实在是干不了什么,就跑到实验室打比赛了~ 之前的比赛补题补了这么久连一场完整的都没补完,结果这场比完后一小 ...
随机推荐
- vue2实现搜索结果中的搜索关键字高亮
// 筛选变色 brightenKeyword(val, keyword) { val = val + ''; if (val.indexOf(keyword) !== -1 && k ...
- DRF 视图组件
目录 DRF 视图组件 视图组件大纲 两个视图基本类 五个扩展类 九个子类视图 视图集 常用视图集父类 魔法类 一览表 DRF中视图的"七十二变" 第一层:基于APIview的五个 ...
- java中程序,进程和线程的区别
2.程序,进程和线程的区别 马克-to-win:程序,进程和线程的区别是什么?这个问题比较抽象难理解,但又非常重要.我并不想给出一大堆抽象的学术解释,那样只能误国误民.所以我先给大家举一个例子.马克- ...
- 【uniapp 开发】UniPush
App.vue export default { onLaunch: function() { // #ifdef APP-PLUS const _self = this; const _handle ...
- jsp+servlet上传excel并将数据导入到数据库表的实现方法
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...
- CCF201609-2火车购票
问题描述 请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配. 假设一节车厢有20排.每一排5个座位.为方便起见,我们用1到100来给所有的座位编号,第一排是1到5号,第二排是6到10 ...
- WIN进程注入&BypassUAC&令牌窃取
WIN进程注入&BypassUAC&令牌窃取 本地提权-win令牌窃取 假冒令牌可以假冒一个网络中的另一个用户进行各类操作. 所以当一个攻击者需要域管理员的操作权限时候,需通过假冒域管 ...
- spring原始注解开发-01
我们使用xml-Bean标签的配置方式和注解做对比理解 1.创建UserDao接口以及UserDao的实现类UserDaoImpl(接口代码省略) public class UserDaoImpl i ...
- 网络编程学习——Linux epoll多路复用模型
前言 后端开发的应该都知道Nginx服务器,Nginx是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器.后端部署中一般使用的就是Nginx反向代理技术. ...
- python基础练习题(题目 文本颜色设置)
day23 --------------------------------------------------------------- 实例035:设置输出颜色 题目 文本颜色设置. 分析:不会, ...