简单的  RMQ;  先预处理得到  所有 节点的 公共祖先  和  dfs 得到所有节点的父亲节点;  然后  询问时,从自己出发向上找父亲, 然后  得到所有的节点;排序一下

不知道  这题这样也能过;为什么不会超时啊???????????;

 #include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<stdio.h>
#include<vector>
using namespace std;
const int maxn = ;
struct date{
int v,next;
}edge[maxn<<]; int total,head[maxn];
int N,Q,node[maxn],fath[maxn];
void add_edge( int u,int v ){
edge[total].v = v;
edge[total].next = head[u];
head[u] = total++;
}
bool vis[maxn]; int dep[maxn<<],sta[maxn<<],tab[maxn<<],dp[maxn<<][],num;
void dfs1( int son,int fa ){
vis[son] = true; fath[son] = fa;
for( int i = head[son]; i != -; i = edge[i].next ){
int v = edge[i].v;
if( !vis[v] )dfs1( v,son );
}
}
void LCA( int son,int deep ){
dep[num] = deep; sta[son] = num; tab[num] = son; num++; vis[son] = true;
for( int i = head[son]; i != -; i = edge[i].next ){
int v = edge[i].v;
if( !vis[v] ){ LCA( v,deep+ ); dep[num] = deep; tab[num] = son; num++; }
}
}
int work( int n1,int n2 ){
if( dep[n1] < dep[n2] )return n1;
return n2;
}
void RMQ( ){
for( int i = ; i <= num; i++ )dp[i][] = i;
for( int i = ; (<<i) <= num; i++ ){
for( int j = ; j - + (<<i) <= num; j++ )
dp[j][i] = work( dp[j][i-], dp[j+(<<(i-))][i-] );
}
}
int query( int L,int R ){
int k = ;
while( (<<(k+)) <= R-L+ )k++;
return tab[work( dp[L][k],dp[R-(<<k)+][k] )];
}
vector<int>vv;
bool cmp( int a,int b ){
return a > b;
}
void DO( int u,int v,int fa,int k ){
vv.clear();
while( u != fa ){
vv.push_back( node[u] );
u = fath[u];
}
while( v != fa ){
vv.push_back( node[v] );
v = fath[v];
}
vv.push_back( node[fa] ); sort( vv.begin(),vv.end(),cmp );
//for( int i = 0; i < vv.size(); i++ )cout<<vv[i]<<endl;
if( vv.size() < k )puts("invalid request!");
else printf("%d\n",vv[k-]);
}
int main(){
while( scanf("%d%d",&N,&Q) != EOF ){
memset( head,-,sizeof(head) ); total = ;
for( int i = ; i <= N; i++ )fath[i] = i;
for( int i = ; i <= N; i++ )scanf("%d",&node[i]);
for( int i = ; i < N; i++ )
{
int u,v; scanf("%d%d",&u,&v);
add_edge( u,v );
add_edge( v,u );
}
memset( vis,,sizeof(vis) );
dfs1( ,- ); fath[] = ;
memset( vis,,sizeof(vis) );num = ;
LCA( , );
//for( int i = 1; i < num; i++ )
//cout<<i<<" "<<dep[i]<<" "<<tab[i]<<endl;
num--; RMQ( );
while( Q-- ){
int k,u,v; scanf("%d%d%d",&k,&u,&v);
if( k == ){ node[u] = v; continue; }
//cout<<node[4]<<endl;
if( sta[u] > sta[v] )swap( u,v );
//cout<<query( sta[u],sta[v] )<<endl;
DO( u,v,query( sta[u],sta[v] ),k );
}
}
return ;
}
/* 7 100
5 1 4 2 4 3 6
1 2
1 3
1 4
2 5
3 6
4 7 */

HDU 3078 Network的更多相关文章

  1. HDU 3078 Network(LCA dfs)

    Network [题目链接]Network [题目类型]LCA dfs &题意: 给出n个点的权值,m条边,2种操作 0 u num,将第u个点的权值改成num k u v,询问u到v这条路上 ...

  2. HDU 3078 Network LCA

    题意:n个点 m个询问,下面一行是n 个点的权值 再下面n-1行是双向的边 然后m个询问:k u v 若k==0,则把u点的权值改为v,否则回答u->v之间最短路经过点的权值中  第k大的值是多 ...

  3. hdu 3078 Network (暴力)+【LCA】

    <题目链接> 题目大意:给定一颗带点权的树,进行两种操作,k=0,更改某一点的点权,k!=0,输出a~b路径之间权值第k大的点的点权. 解题分析:先通过RMQ的初始化,预处理pre[]数组 ...

  4. HDU - 3078 Network(暴力+LCA)

    题目大意:给出n个点的权值.m条边,2种操作 0 u num,将第u个点的权值改成num k u v,询问u到v这条路上第k大的权值点 解题思路:该点的话直接该,找第k大的话直接暴力 #include ...

  5. HDU 2460 Network(双连通+树链剖分+线段树)

    HDU 2460 Network 题目链接 题意:给定一个无向图,问每次增加一条边,问个图中还剩多少桥 思路:先双连通缩点,然后形成一棵树,每次增加一条边,相当于询问这两点路径上有多少条边,这个用树链 ...

  6. HDU 3078:Network(LCA之tarjan)

    http://acm.hdu.edu.cn/showproblem.php?pid=3078 题意:给出n个点n-1条边m个询问,每个点有个权值,询问中有k,u,v,当k = 0的情况是将u的权值修改 ...

  7. HDU 3078 (LCA+树链第K大)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3078 题目大意:定点修改.查询树中任意一条树链上,第K大值. 解题思路: 先用离线Tarjan把每个 ...

  8. HDU 2460 Network(桥+LCA)

    http://acm.hdu.edu.cn/showproblem.php?pid=2460 题意:给出图,求每次增加一条边后图中桥的数量. 思路: 先用tarjan算法找出图中所有的桥,如果lowv ...

  9. hdu 3078(LCA的在线算法)

    Network Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

随机推荐

  1. (转)白话经典算法系列之八 MoreWindows白话经典算法之七大排序总结篇

    在我的博客对冒泡排序,直接插入排序,直接选择排序,希尔排序,归并排序,快速排序和堆排序这七种常用的排序方法进行了详细的讲解,并做成了电子书以供大家下载.下载地址为:http://download.cs ...

  2. 浅说Java中的反射机制(二)

    写过一篇Java中的反射机制,不算是写,应该是抄了,因为那是别人写的,这一篇也是别人写的,摘抄如下: 引自于Java基础--反射机制的知识点梳理,作者醉眼识朦胧.(()为我手记) 什么是反射? 正常编 ...

  3. JQuery的第一天实战学习

    1.按照下面的工程来建: 2.新建UserVerify.html文件: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitiona ...

  4. CentOS系统常用命令

    1.进入目录命令 cd /usr/bin //进入etc目录 cd .. //切换到上一层目录 cd / //进入主目录 2.新建文件命令 比如进入某个目录后执行 vim test 2.查看运行的项目 ...

  5. Centos环境下部署游戏服务器-自动化

    计算机是没有智力的,只会接受指令,运行指令,得出结果.因此就算你让它重复做一件事多少次,它也学不会自动去做这件事.对于重复繁琐的事情,做为一个懒惰的程序员,必须告诉机器去做这件事情,然后就行了,而不是 ...

  6. ADB not responding. You can wait more,or kill"abd.exe" process manually and click 'Restart'

    在使用Android Studio进行开发的过程中,有时候编译运行时,会出现如下提示: ADB not responding. You can wait more,or kill"abd.e ...

  7. iOS中检测硬件和传感器

    首先要知道,你需要查看所需的硬件或传感器是否存在,而不是假设设备有哪些功能.举个例子,你不能假设只有iPhone才有麦克风,而应该使用API来查看麦克风是否存在.下面这段代码的第一个优势在于,它能自动 ...

  8. [iOS]ARC和MRC下混编

    1.在MRC工程中使用ARC的文件(例如AFNetworking,SDWebImage,MJRefresh等)在Build Phases里找到对应.m 在后面添加-fobjc-arc(代表这个文件使用 ...

  9. JavaScript ECAMScript5 新特性——get/set访问器

    之前对get/set的理解一直有误,觉得get set 是对象属性方法.看了别人的博客也有很多疑问,今天系统的做了很多测试终于弄明白了.(自己通过看书和写demo测试的,如有不对欢迎大家批评指正) g ...

  10. Hibernate的配置文件解析

    配置mybatis.xml或hibernate.cfg.xml报错: <property name="connection.url">jdbc:mysql://loca ...