倍增法 lca codevs 1036 商務旅行

2022-09-17 05:30:19 字數 1389 閱讀 4977

時間限制: 1 s

空間限制: 128000 kb

題目等級 : 鑽石 diamond

某首都城市的商人要經常到各城鎮去做生意,他們按自己的路線去做,目的是為了更好的節約時間。

假設有n個城鎮,首都編號為1,商人從首都出發,其他各城鎮之間都有道路連線,任意兩個城鎮之間如果有直連道路,在他們之間行駛需要花費單位時間。該國公路網路發達,從首都出發能到達任意乙個城鎮,並且公路網路不會存在環。

你的任務是幫助該商人計算一下他的最短旅行時間。

輸入描述 input description

輸入檔案中的第一行有乙個整數n,1<=n

<=30 000,為城鎮的數目。下面n-1行,每行由兩個整數a 和b (1<=a, b

<=n; a<>b)組成,表示城鎮a和城鎮b有公路連線。在第n+1行為乙個整數m,下面的m行,每行有該商人需要順次經過的各城鎮編號。

輸出描述 output description

在輸出檔案中輸出該商人旅行的最短時間。

樣例輸入 sample input

5
1 2
1 5
3 5
4 5
4
1
3
2
5

樣例輸出 sample output

7

1

#define n 60100

2 #include3

using

namespace

std;

4 #include5 #include6

#define c 20

7 typedef long

long

ll;8

int ance[n>>1][c],dis[n>>1

],n,a,b,m;

9 ll sum=0;10

struct

edgeedge[n<<1

];13

int deep[n>>1],head[n>>1],t=0;14

void add_edge(int u,int

v)15

21void

input()

2230}31

void dfs(int

k)3242}

43}44void

chuli_ance()

4550

int lca(int a,int

b)5167}

68return ance[a][0

];69}70

intmain()

7188 sum+=dis[sta];

89 cout90return0;

91 }

LCA倍增法模板

deg其實應該寫成depth吧,存的是每個結點的深度,dfs的過程是為了處理出每個結點的深度,用遞推式計算出fa u i 其中f u i 表示u的第2 i個祖先 基本思想是 d i 表示 i節點的深度,p i,j 表示 i 的 2 j 倍祖先 那麼就有乙個遞推式子 p i,j p p i,j 1 j...

字尾陣列倍增法

字尾陣列 字尾陣列是處理字串的有力工具。字尾陣列是字尾樹的乙個非常精巧的替代品,它比字尾樹容易程式設計實現,能夠實現字尾樹的很多功能而時間複雜度也並不遜色,而且它比字尾樹所占用的記憶體空間小很多。可以說,在資訊學競賽中字尾陣列比字尾樹要更為實用。1.1 基本定義 子串 字串s的子串r i.j i j...

倍增法求 LCA

預處理 通過dfs遍歷,記錄每個節點到根節點的距離dist u 深度d u 並求出樹上每個節點i的2 j祖先f i j 求最近公共祖先,根據兩個節點的的深度,如不同,向上調整深度大的節點,使得兩個節點在同一層上,如果正好是祖先結束,否則,將連個節點同時上移,查詢最近公共祖先。include incl...