如題,給定一棵有根多叉樹,請求出指定兩個點直接最近的公共祖先。
輸入格式:
第一行包含三個正整數n、m、s,分別表示樹的結點個數、詢問的個數和樹根結點的序號。
接下來n-1行每行包含兩個正整數x、y,表示x結點和y結點之間有一條直接連線的邊(資料保證可以構成樹)。
接下來m行每行包含兩個正整數a、b,表示詢問a結點和b結點的最近公共祖先。
輸出格式:
輸出包含m行,每行包含乙個正整數,依次為每乙個詢問的結果。
輸入樣例#1: 複製
5 5 4輸出樣例#1: 複製3 12 4
5 11 4
2 43 2
3 51 2
4 5
441時空限制:1000ms,128m44
資料規模:
對於30%的資料:n<=10,m<=10
對於70%的資料:n<=10000,m<=10000
對於100%的資料:n<=500000,m<=500000
樣例說明:
該樹結構如下:
第一次詢問:2、4的最近公共祖先,故為4。
第二次詢問:3、2的最近公共祖先,故為4。
第三次詢問:3、5的最近公共祖先,故為1。
第四次詢問:1、2的最近公共祖先,故為4。
第五次詢問:4、5的最近公共祖先,故為4。
故輸出依次為4、4、1、4、4。
哈哈哈哈哈哈
放一天多的假
哈哈哈哈哈
那我當然要嘚瑟嘚瑟啦
哈哈哈哈哈哈
**:
#include#include如果你不開心,那我就把右邊這個帥傻子分享給你吧,#include
#include
#include
using
namespace
std;
const
int n=5e5+7
;int
n,enum,m,s;
int front[n],fat[n][20
],deep[n];
struct
node
e[n<<1
];int
qread()
returnx;}
void insert(int u,int
v)void dfs(intx)}
void
find_father()
int lca(int a,int
b)
return fat[a][0];}
intmain()
dfs(s);
find_father();
for(int i=1; i<=m; i++)
return0;
}
你看,他這麼好看,那麼深情的望著你,你還傷心嗎?
真的!這**盯上他五秒鐘就想笑了。
一切都會過去的。
P3379 模板 最近公共祖先(LCA)
如題,給定一棵有根多叉樹,請求出指定兩個點直接最近的公共祖先。第一行包含三個正整數n m s,分別表示樹的結點個數 詢問的個數和樹根結點的序號。接下來n 1行每行包含兩個正整數x y,表示x結點和y結點之間有一條直接連線的邊 資料保證可以構成樹 接下來m行每行包含兩個正整數a b,表示詢問a結點和b...
P3379 模板 最近公共祖先(LCA)
如題,給定一棵有根多叉樹,請求出指定兩個點直接最近的公共祖先。第一行包含三個正整數n m s,分別表示樹的結點個數 詢問的個數和樹根結點的序號。接下來n 1行每行包含兩個正整數x y,表示x結點和y結點之間有一條直接連線的邊 資料保證可以構成樹 接下來m行每行包含兩個正整數a b,表示詢問a結點和b...
P3379 模板 最近公共祖先(LCA)
如題,給定一棵有根多叉樹,請求出指定兩個點直接最近的公共祖先。輸入輸出格式 輸入格式 第一行包含三個正整數n m s,分別表示樹的結點個數 詢問的個數和樹根結點的序號。接下來n 1行每行包含兩個正整數x y,表示x結點和y結點之間有一條直接連線的邊 資料保證可以構成樹 接下來m行每行包含兩個正整數a...