時間限制: 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...