2017 Shenyang onsite replay L - Tree
這裡主要補一下L題,感覺也是挺巧妙的,不過也不難
題目大意:
給予一個無根樹,然後給予K種顏色,求將所有顏色的點都連線起來,這K種顏色最多有多少條公共的邊。
解題思路:
- 首先看一個圖,我們直接拆分邊,如果這個邊的兩端都有>=k 個點,那麼這條邊就可以公共通過。
- 假如K == 3, 那麼如果我切割中間的邊, 那麼左右的點的數目都是 >= 3 ,就符合條件,所以我們根據這個性質來繼續解題。
- 因此我們只需要找一個點作為根即可。(找度為1的點,比較方便)
- 然後我們記錄每個點有多少個子節點,然後我們去遍歷每個點,他的子節點 和 n - 子節點 ,判斷這兩個數值是否 >= k 即可,累加統計
程式碼:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#include <unordered_map>
#include <stack>
#include <cmath>
#include <deque>
using namespace std;
typedef long long ll;
const int N = 200010, M = 400010;
const int mod = 1e9 + 7;
pair <int,int> ans[N];
int h[N], e[M], ne[M], idx;
int d[N];
int b[N];
int num = 1;
void add(int x, int y){
e[idx] = y, ne[idx] = h[x], h[x] = idx ++;
}
void dfs(int u, int f){
b[u] = 1;
for (int i = h[u]; i != -1; i = ne[i]){
int j = e[i];
if (j != f){
dfs(j,u);
}
}
if (f != -1) b[f] += b[u];
}
int main(){
int t;
scanf("%d",&t);
while(t--){
idx = 0;
memset(d,0,sizeof d);
memset(h,-1,sizeof h);
int n, k;
scanf("%d%d",&n,&k);
for (int i = 1; i <= n - 1; i ++){
int x, y;
scanf("%d%d",&x,&y);
ans[i] = {x,y};
d[x] ++, d[y] ++;
add(x,y), add(y, x);
}
int res = 0;
int x;
for (int i = 1; i <= n; i++){
if (d[i] == 1){
x = i;
}
}
dfs(x, -1);
for (int i = 1; i <= n; i++){
if (b[i] >= k && n - b[i] >= k) res ++;
}
printf("%d\n",res);
}
return 0;
}
相關文章
- 【賽後補題】(HDU6228) Tree {2017-ACM/ICPC Shenyang Onsite}ACM
- CSRFwithupload–XHR-L2,HTML5andCookiereplayHTMLCookie
- 2017 ACM/ICPC Asia Regional Shenyang Online - 做題記錄ACM
- Facebook 電面+Onsite面經
- Y! onsite新鮮面經
- TcpreplayTCP
- Oracle Database ReplayOracleDatabase
- The 2021 ICPC Asia Shenyang Regional Contest
- goreplay 使用教程Go
- oracle rat database replayOracleDatabase
- Oracle replayc測試Oracle
- database replay基礎學習Database
- Apple 面試寶典 – HR, 電面, Onsite 準備建議APP面試
- Apple 面試寶典 - HR, 電面, Onsite 準備建議APP面試
- Tree
- l
- 華納廳開代理會員l846987l87l
- 強化學習(十一) Prioritized Replay DQN強化學習Zed
- iOS ReplayKit 與 螢幕錄製iOS
- 資料庫負荷重放(Database replay)資料庫Database
- 11g Database Replay使用詳解Database
- Oracle 11g Database Replay 實驗OracleDatabase
- Rebuild TreeRebuild
- 01 Tree
- DSU on Tree
- 解決Aireplay-ng通道問題AI
- 【MySQL(1)| B-tree和B+tree】MySql
- 2018 ICPC-ACM shenyang G - Best ACMer Solves the Hardest ProblemACM
- 多路查詢樹:B-tree/b+tree
- 視訊重播轉換器:Replay Converter MacMac
- HTTP流量神器Goreplay核心原始碼詳解HTTPGo原始碼
- 錄音軟體:Applian Replay Music for macAPPMac
- Oracle 資料庫重放(Database Replay)功能演示Oracle資料庫Database
- 執行database replay進行升級測試Database
- 輕量級流量複製goreplay實踐Go
- grep: PCRE does not support L, l, N{name}, U, or u
- layui Tree修改UI
- Tree Compass