日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

树形结构 —— 树与二叉树 —— 树的直径

發布時間:2025/3/17 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 树形结构 —— 树与二叉树 —— 树的直径 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【定義】

給定一棵樹,樹中的每條邊都有一個權值。

  • 樹中兩點的距離:連接兩點的路徑邊權之和
  • 樹的直徑:樹中最遠的兩個節點之間的距離
  • 樹的最長鏈:連接樹中最遠的兩個結點的路徑

【實現】

樹的直徑通常有兩種求法,時間復雜度均為O(n)。

假設樹以 n 個點 n-1 條邊的無向圖形式給出,存儲在鄰接表中。

1.兩次DFS求樹的直徑

通過兩次 dfs 可以求樹的直徑,且更容易計算出直徑上的具體結點

  • 從任意結點出發,通過 dfs 對樹進行一次遍歷,求出于出發點距離最遠的結點,記為 st
  • 從結點 st 出發,通過 dfs 對樹再進行一次遍歷,求出于 st 距離最遠的結點,記為 ed
  • 則:st 到 ed 的路徑就是樹的直徑

    在第 2 步的遍歷中,可以記錄下來每個點第一次被訪問的前驅節點,最后從 q 遞歸到 p,即可得到直徑的具體方案

    struct Edge {int to, val;int next;Edge(){}Edge(int to,int val,int next):to(to),val(val),next(next){} } edge[N]; int n; int head[N], tot; int dis[N], maxx, id; int st, ed, diameter;//起點、終點、直徑 int disSt[N], disEd[N];//起點、終點分別到每個點的距離 void addEdge(int from, int to, int val) {edge[++tot].to = to;edge[tot].val = val;edge[tot].next = head[from];head[from] = tot; } void dfs(int x, int father) {for (int i = head[x]; i != -1; i = edge[i].next) {int y = edge[i].to;int val = edge[i].val;if (y == father)continue;dis[y] = dis[x] + val;if(dis[y]>maxx){maxx = dis[y];id = y;}dfs(y, x);} } void calcDiameter(){//第一遍dfsmaxx = 0;id = 1;dfs(1, 0);st = id;//第二遍dfsmaxx = 0;dis[st] = 0;dfs(st, 0);ed = id;diameter = maxx; //樹的直徑for (int i = 1; i <= n; i++)disSt[i] = dis[i];dis[ed] = 0;dfs(ed, 0);for (int i = 1; i <= n; i++)disEd[i] = dis[i]; }int main() {scanf("%d", &n);memset(head, -1, sizeof(head));for (int i = 1; i <= n - 1; i++) {int x, y, val;scanf("%d%d%d", &x, &y, &val);addEdge(x, y, val);addEdge(y, x, val);}calcDiameter();printf("%d %d\n", st, ed);printf("%d\n", diameter);return 0; }

    2.樹形DP求樹的直徑

    設 1 號節點為根,n 個點 n-1 條邊的無向圖就可以看做有根樹

    設 dis1[x] 表示從點 x 到以 x 為根的子樹中葉結點的最長鏈, pos1[x] 表示 dis1[x] 在哪個點更新;dis2[x] 表示從點 x 到以 x 為根的子樹中葉結點的次長鏈,pos2[x] 表示 dis2[x] 在哪個點更新,且要求兩條鏈不能有交集。

    這樣一來,對于任意一點 i,經過點 i 的最長鏈的分為兩個部分:i 的最長鏈 dis1[i]、i 的次長鏈 dis2[i]

    那么,整棵樹的直徑就是

    struct Edge {int to, val;int next;Edge(){}Edge(int to,int val,int next):to(to),val(val),next(next){} } edge[N]; int n; int head[N], tot; int dis1[N], dis2[N];//分別維護第i個點的最長鏈、次長鏈 int pos1[N],pos2[N];//分別維護dis1[i]、dis2[i]從哪個點更新 void addEdge(int from, int to, int val) {edge[++tot].to = to;edge[tot].val = val;edge[tot].next = head[from];head[from] = tot; } void dfs(int x, int father) {for (int i = head[x]; i != -1; i = edge[i].next) {int y = edge[i].to;int val = edge[i].val;if (y == father)continue;dfs(y, x);if (dis1[y] + val > dis1[x]) {dis2[x] = dis1[x];dis1[x] = dis1[y] + val;pos2[x] = pos1[x];pos1[x] = y;} else if (dis1[y] + val > dis2[x]) {dis2[x] = dis1[y] + val;pos2[x] = y;}} } int main() {scanf("%d", &n);memset(head, -1, sizeof(head));for (int i = 1; i <= n - 1; i++) {int x, y, val;scanf("%d%d%d", &x, &y, &val);addEdge(x, y, val);addEdge(y, x, val);}dfs(1, 0);int diameter = -INF;for (int i = 1; i <= n; i++)diameter = max(dis1[i] + dis2[i], diameter);printf("%d", diameter);return 0; }

    ?

    總結

    以上是生活随笔為你收集整理的树形结构 —— 树与二叉树 —— 树的直径的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 精品天堂| 日本女人hd | 欧美日韩国产精品综合 | 爱情岛论坛亚洲线路一 | 欧美国产日韩在线观看成人 | 中文不卡在线 | 韩国av在线免费观看 | h片在线观看免费 | 日韩午夜剧场 | 伊人久在线 | 亚洲综合五月天婷婷丁香 | 偷偷操不一样的99 | 亚洲综合色在线 | 国产91精品一区 | 九九99精品视频 | 国产精品成人无码免费 | 亚洲欧美日韩精品色xxx | 日本青青草视频 | 一区二区三区波多野结衣 | 污污网站在线免费观看 | 一级片在线免费看 | 国产麻豆精品在线 | 亚洲综合激情 | 日本一二三不卡 | 九九精品网 | 男生操女生逼逼 | 欧美成人777| 人妻丰满熟妇无码区免费 | 99久久久无码国产精品免费 | 蜜桃av免费| 网站免费黄色 | 精品国模 | 手机看片日本 | 日韩影院一区 | 国产日批视频 | 成人无码久久久久毛片 | 刘亦菲国产毛片bd | 偷拍欧美亚洲 | 深夜福利网 | 日韩精品导航 | 亚洲视频成人 | 美日韩免费 | 成人免费毛片男人用品 | aaa人片在线 | 丰满人妻一区二区三区四区 | 欧美乱做爰xxxⅹ久久久 | 国产91精品一区二区麻豆亚洲 | 亚洲va中文字幕 | 在线免费视频你懂的 | 夜夜福利| 伊人久久天堂 | 日本午夜网 | 在线欧美a | 91九色论坛 | 国产做爰高潮呻吟视频 | 性一交一乱一色一免费无遮挡 | 欧美性生交xxxxx久久久缅北 | 在线免费观看麻豆 | 日韩污视频在线观看 | 亚洲精品九九 | 亲吻刺激视频 | 欧美日韩八区 | 国产精品九色 | 蜜桃视频在线观看www | 色噜噜日韩精品欧美一区二区 | 亚洲精品视频在线观看视频 | 午夜久久久久久久久久久 | 成年人在线播放视频 | 亚洲精品国产精品乱码不99 | 视频区图片区小说区 | 亚洲人xxxx | 99热网站 | 日韩亚洲视频 | 撸啊撸av | 久久久久久久久艹 | 欧美久久久久久久久久久久久久 | 亚洲av无码一区二区三区人 | 免费欧美黄色片 | 黑人一级黄色片 | 九九亚洲视频 | 视频黄色免费 | 北条麻妃一二三区 | 国产精品视频h | 久久精品视频8 | 亚洲自拍av在线 | 射一射 | 在线免费观看小视频 | 国产在线观看无码免费视频 | 久久精品视频中文字幕 | 亚洲日本在线观看视频 | 日韩国产电影 | 日本精品久久久 | 国内精品人妻无码久久久影院蜜桃 | 精品免费一区二区 | youjizz日本人 | 亚洲伦理精品 | 亚洲视频一二三区 | 999久久久久久| 久久久精品一区二区涩爱 |