小明生活在一个名为running的国家,该国家由 n 个城市组成,编号从 1 到 n,还有 n−1 条双向道路连接着这些城市。从任何一个城市都可以到达另一个城市。每条道路都连接着两个城市 a 和b 。这个国家是一个热爱跑步的国家,因此每天都会在一对城市 (u ,v)之间举办一次马拉松,从 u 作为起点, v 作为终点,且 u != v 。小明需要用最短的路径到达从 u 到达 v(注意 (u ,v) 和 (v ,u) 是不同的马拉松)。
令小明头疼的是该国家有两个城市 x 和 y,当小明经过 x 城市后又跑到 y 城市,那么该城市的警察就会阻止小明继续参加比赛。
小明想知道在举办的所有马拉松路线中他会有多少个马拉松会在他参加时会被警察阻止。
输入描述:
第一行包含三个整数 n、 x 和 y (2≤n≤3⋅10^5、1≤x , y≤n 、x≠y) -- 分别是城市数量、x 城市的编号和 y 城镇的编号。
接下来是 n-1 行,每行包含两个整数 a 和 b (1≤a ,b≤n , a≠b),描述了连接两个城镇 a 和 b 的道路。
可以保证的是,从每个城镇出发,我们都可以通过给定的道路到达城市中的其他城镇。也就是说,给定的城镇和道路地图是一棵树。他会有多少个马拉松会在他参加时会被警察阻止。
输出描述:
一个整数,表示小明在参加马拉松时会被警察阻止的数量 (u , v) 。
示例1
输入
5 1 5 1 2 2 3 3 4 4 5
输出
1
示例2
输入
5 1 5 1 2 1 3 1 4 1 5
输出
4
示例3
输入
5 2 3 1 2 1 3 2 4 1 5
输出
2
#include <bits/stdc++.h>
using namespace std;
const int N = 1e6+5;
typedef long long ll;
bool st[1000010];
vector<int> v[1000010];
int n, x, y;
ll cnt1 = 1, cnt2 = 1;
void dfs(int u)
{
st[u] = true;
for(int i=0;i<(int)v[u].size();i++)
{
int j = v[u][i];
if(st[y]) break;
if(!st[j]) dfs(j);
}
if(!st[y]) st[u] = false;
}
void dfs1(int u)
{
st[u] = true;
for(int i=0;i<(int)v[u].size();i++)
{
int j = v[u][i];
if(!st[j])
{
dfs1(j);
cnt1++;
}
}
}
void dfs2(int u)
{
st[u] = true;
for(int i=0;i<(int)v[u].size();i++)
{
int j = v[u][i];
if(!st[j])
{
dfs2(j);
cnt2++;
}
}
}
int main()
{
cin>>n>>x>>y;
for(int i=0;i<n-1;i++)
{
int a, b;
cin>>a>>b;
v[a].push_back(b);
v[b].push_back(a);
}
dfs(x);
dfs1(x);
dfs2(y);
ll ans = cnt1 * cnt2;
cout<<ans<<'\n';
}