hdu - 2586 How far away ?(最短路共同祖先問題)

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=2586

?

最近公共祖先問題~~LAC離散算法

題目大意:一個村子里有n個房子,這n個房子用n-1條路連接起來,接下了有m次詢問,每次詢問兩個房子a,b之間的距離是多少。

很明顯的最近公共祖先問題,先建一棵樹,然后求出每一點i到樹根的距離dis[i],然后每次詢問a,b之間的距離=dis[a]+dis[b]-2*dis[LCA(a,b)];

LCA(a,b)即是a,b的最近公共祖先。。

關于最近公共祖先,給大家推薦一個學長的博客http://www.cnblogs.com/ylfdrib/archive/2010/11/03/1867901.html,里面講的很不錯!!

?

 1 # include<stdio.h>
 2 # include<string.h>
 3 # define N 40005
 4 # define M 205
 5 struct node{
 6     int from,to,next,val;
 7 }edge[2*N];
 8 struct node1{
 9     int from,to,next,num;
10 }edge1[2*M];
11 int tol,head[N],head1[N],tol1,father[N],dis[N],LCA[M],n,m;
12 bool visit[N];
13 void add(int a,int b,int c)
14 {
15     edge[tol].from=a;edge[tol].to=b;edge[tol].next=head[a];edge[tol].val=c;head[a]=tol++;
16 }
17 void add1(int a,int b,int c)
18 {
19     edge1[tol1].from=a;edge1[tol1].to=b;edge1[tol1].next=head1[a];edge1[tol1].num=c;head1[a]=tol1++;
20 }
21 int find(int x)
22 {
23     if(x!=father[x])
24         father[x]=find(father[x]);
25     return father[x];
26 }
27 void tarjan(int u)
28 {
29     int j,v;
30     visit[u]=1;
31     father[u]=u;
32     //
33     for(j=head1[u];j!=-1;j=edge1[j].next)
34     {
35         v=edge1[j].to;
36         if(visit[v]) LCA[edge1[j].num]=find(v);
37     }
38     //
39     for(j=head[u];j!=-1;j=edge[j].next)
40     {
41         v=edge[j].to;
42         if(!visit[v]) 
43         {
44             dis[v]=dis[u]+edge[j].val;
45             tarjan(v);
46             father[v]=u;
47         }
48     }
49 }
50 int main()
51 {
52     int i,ncase,a,b,c;
53     scanf("%d",&ncase);
54     while(ncase--)
55     {
56         scanf("%d%d",&n,&m);
57         tol=0;
58         memset(head,-1,sizeof(head));
59         for(i=1;i<n;i++)
60         {
61             scanf("%d%d%d",&a,&b,&c);
62             add(a,b,c);
63             add(b,a,c);
64         }
65         memset(visit,0,sizeof(visit));
66         tol1=0;
67         memset(head1,-1,sizeof(head1));
68         for(i=1;i<=m;i++)
69         {
70             scanf("%d%d",&a,&b);
71             add1(a,b,i);
72             add1(b,a,i);
73         }
74         ///LCA是一種離線算法,所以剛開始需要把所有的詢問都輸入,然后用鄰接表進行存儲,i表示第i次詢問
75         dis[1]=0;
76         tarjan(1);
77         for(i=0;i<tol1;i+=2)
78         {
79             a=edge1[i].from;
80             b=edge1[i].to;
81             c=edge1[i].num;
82             printf("%d\n",dis[a]+dis[b]-2*dis[LCA[c]]);
83         }
84     }
85     return 0;
86 }

?

**************************

?

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <iostream>
 4 #include <vector>
 5 using namespace std;
 6 
 7 const int NN=50010;
 8 
 9 int n,m;
10 vector<pair<int,int> > edge[NN],qe[NN];
11 vector<int> q1,q2;
12 
13 int p[NN];
14 int find(int x)
15 {
16     if (p[x]!=x) p[x]=find(p[x]);
17     return p[x];
18 }
19 
20 int sum=0,ans[NN],dis[NN];
21 bool vis[NN]={0};
22 void lca(int u,int fa)
23 {
24     p[u]=u;
25     for (int i=0; i<edge[u].size(); i++)
26     {
27         int v=edge[u][i].first;
28         if (v==fa) continue;
29         dis[v]=dis[u]+edge[u][i].second;
30         lca(v,u);
31         p[v]=u;
32     }
33     vis[u]=true;
34     if (sum==m) return;
35     for (int i=0; i<qe[u].size(); i++)
36     {
37         int v=qe[u][i].first;
38         if (vis[v])
39             ans[qe[u][i].second]=dis[u]+dis[v]-2*dis[find(v)];
40     }
41 }
42 
43 int main()
44 {
45     int u,v,w;
46 
47     int t;
48     scanf("%d",&t);
49     while(t--){
50     scanf("%d%d",&n,&m);
51     for (int i=1; i<=n; i++)
52     {
53         edge[i].clear();
54     }
55     for (int i=1; i<n; i++)
56     {
57         scanf("%d%d%d",&u,&v,&w);
58         edge[u].push_back(make_pair(v,w));
59         edge[v].push_back(make_pair(u,w));
60     }
61 
62     for (int i=0; i<m; i++)
63     {
64         scanf("%d%d",&u,&v);
65         qe[u].push_back(make_pair(v,i));
66         qe[v].push_back(make_pair(u,i));
67         ans[i]=0;
68     }
69     dis[1]=0;
70     lca(1,0);
71     for (int i=0; i<m; i++) printf("%d\n",ans[i]);
72     }
73     return 0;
74 }

?

轉載于:https://www.cnblogs.com/weiyuan/p/5758012.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/286690.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/286690.shtml
英文地址,請注明出處:http://en.pswp.cn/news/286690.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Android之添加固定圖標到桌面

我的QQ群 1 需求 Android之添加固定圖標到桌面 2 部分實現 在AndroidManifest.xml里面添加如下權限 <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" /><uses-permission android:name="com.android.launcher.perm…

想做程序員?不同方向入門路線全解

學習計算機編程有很多方向如果你沒有一個正確的路線&#xff0c;那么就會&#xff1a; 就會跟上面所說的那樣&#xff0c;被迫成為一個全棧&#xff0c;這是比較尷尬的。 若你想比較準確的針對某個方向學習&#xff0c;那就繼續往下看吧。 一、程序員分為哪幾個方向 隨著…

【轉】OpenGL超級寶典筆記——紋理映射Mipmap

原文地址 http://my.oschina.net/sweetdark/blog/177812 , 感謝作者&#xff0c;若非法轉載請聯系本人。 目錄[-] MipmappingMipmap過濾構建Mip層Mipmaps 硬件生成LOD&#xff08;多細節層次&#xff09;偏好紋理對象管理多個紋理常駐紋理紋理優先級回顧Mipmapping Mipmap是一個…

【Microstation】第二章:Microstation三維建模基礎知識

本章的主要內容包括模型的顯示樣式(線框、光滑)、三維定位(V、T、S、F)、Microstation常見的坐標系統(世界坐標系、ACS輔助坐標系、精確繪圖坐標系、)和Microstation的工作區域(2D和3D)。 一、顯示樣式 二、三維定位 三維定位在Microstation中顯得尤為重要,常見…

xtrabackup對MySQL數據庫的備份及恢復教程

xtrabackup xtrabackup 是 percona 的一個開源項目&#xff0c;可以熱備份innodb &#xff0c;XtraDB,和MyISAM&#xff08;會鎖表&#xff09;。對MyISAM存儲引擎會鎖表&#xff0c;也是很郁悶的因為線上使用的是Innodb和MyISAM兩種存儲引擎&#xff0c;比較 頭疼&#xff01;…

實現 EF Core 6 自定義查詢標記

前言在《EF Core使用Simple Logging輸出日志》中&#xff0c;我們介紹了查詢標記 TagWith&#xff0c;它可以幫助我們快速定位到需要的日志&#xff1a;而在 .NET 6 中&#xff0c;新增了另外一個查詢標記 TagWithCallSite&#xff0c;它可以標記出代碼的位置&#xff1a;var u…

LeetCode: 14. Longest Common Prefix

Write a function to find the longest common prefix string amongst an array of strings. 大意就是&#xff0c;寫一個函數可以找到一個數組字符串中的最長前綴。 分析&#xff1a; 最長前綴的最大值為數組字符串中長度最短的字符&#xff0c;由最短字符串由后向前遞減可以得…

jQuery選擇器和選取方法

我們已經使用了帶有簡單Css選擇器的jQuery選取函數:$()。現在是時候深入了解jQuery選擇器語法&#xff0c;以及一些提取和擴充選中元素集的方法了。 一、jQuery選擇器 在CSS3選擇器標淮草案定義的選擇器語法中&#xff0c;jQuery支持相當完整的一套子集&#xff0c;同時還添加了…

0運維?微信小程序云開發增刪查改【05】

在創建小程序時&#xff0c;選擇云開發&#xff1a; 隨后進入項目之后&#xff0c;此時整個目錄如下&#xff1a; 此時我們如圖目錄即可找到首頁位置&#xff1a; 接著咱們清除 index.wxml 代碼內容&#xff1a; 在 index.wxml 中加入如下代碼&#xff1a; <view> …

Android之解決卸載app后再次安裝提示room數據庫錯誤

1、問題 目前只有一個google手機之前安裝了app,里面有room寫的數據庫&#xff0c;后面把app卸載了&#xff0c;再次安裝新的app(修改了數據庫里面的字段)&#xff0c;啟動奔潰。 2、分析 提示數據庫錯誤&#xff0c;很明顯就像以前的app里面的數據庫沒有刪除一樣&#xff0c;…

【Microstation】第三章:Microstation三維模型構建與編輯

本章主要講述三維基本實體繪制、三維構造元素繪制、三維模型編輯。 一、三維基本體素繪制 對于立方體、圓柱、球、圓錐等這些基本立體單位,MS提供了專門的繪圖工具。 基本體素繪制有兩種方式: (1)精確繪圖工具 (2&

文件系統管理相關命令

查看文件系統相關屬性的命令&#xff1a;blkidblkid是一個查看磁盤設備屬性相關信息的命令行工具blkid -L LABEL | UUID :根據UUID查看對應的設備是哪個blkid [-ghlv] [-c file] [-w file] [-o format][-s tag] [-t NAMEvalue] device [device ...]-i&#xff1a;顯示io限制lsb…

CSharpFunctionalExtensions -函數式編程C#的功能擴展

簡介該庫有助于以更實用的方式編寫代碼安裝在NuGet上可用dotnet add package CSharpFunctionalExtensions或者PM> Install-Package CSharpFunctionalExtensions例子Maybe創建一個值Maybe<string> apple Maybe<string>.From("apple");// orMaybe<s…

Android之實現夸克瀏覽器書簽和歷史頁面滑動時候右上角圖標切換效果

1 需求 實現夸克瀏覽器書簽和歷史頁面滑動時候右上角圖標切換效果,頁面滑動的時候,圖標也左右滑動,但是只是顯示其中的一個 https://www.captainai.net/st/ 2 代碼實現 xml布局實現 <LinearLayoutandroid:id="@+id/mainLl"android:layout_width="24d…

ArcGIS 10.6字段計算器(Field Calculator)字段任意填充編碼序列(奇數、偶數序列、自定義間隔)

有關ArcGIS 10.x中屬性數據采集和字段計算器(Field Calculator)的文章,需要的讀者可以參照: 《ArcGIS實驗教程——實驗四:數字化屬性數據的采集》,文章中就屬性數據采集的多種方式做了說明,其中就有字段計算器的詳細說明;《【ArcGIS風暴】ArcGIS 10.2字段計算器(Field…

你都用 Python 來做什么?

你們都用python做些什么呢&#xff1f; 在開發中 python 這一個語言就像是小叮當&#xff0c;而 python 的第三方庫則是“百寶箱”&#xff0c;你只要想著對某一個方向進行開發&#xff0c;那么這個“百寶箱”就會給你想要的東西。 由于我是在開發多年后接觸到的 python&#…

DOS分區概述

雖然很多參考文檔對DOS分區進行介紹&#xff0c;但一直沒有一個統一的標準&#xff0c;也沒有統一的命名規則。Microsoft將使用DOS分區體系的磁盤稱為“主引導記錄(Master Boot Recorder---MBR)磁盤”&#xff0c;這是相對于使用“全局ID分區表(GUID Partition Table---GPT)磁盤…

pdf.js 利用HTML5技術顯示pdf內容

Mozilla實驗室最近在github上開源了一款js庫pdf.js&#xff0c;用來讀取PDF文件。 http://mozilla.github.io/pdf.js/ Using base64 encoded PDF HTML頁面內容 <script src"//mozilla.github.io/pdf.js/build/pdf.js"></script><h1>PDF.js Hell…

.NET 對于構建系統應用的探索歷程

這篇文章介紹和梳理一下截止到 2022 年的 .NET 向系統編程探索的歷程。2003 年的 Singularity 項目試圖讓 Windows 的內核態與用戶態應用完全建立在 .NET 托管世界上&#xff0c;并試驗了一個支持編譯到本機代碼的類似 C# 的語言&#xff0c;并發布了很多相關的論文。后來 Sing…

Android之tint圖片著色器

1、爆照 上面是原圖,下面是點擊效果。 2、介紹 設置著色模式用的。這個模式共有6種,分別為: multiply screen src_in(默認) src_over src_atop add android:tint 屬性可以改變圖片顏色 3 源代碼 colors.xml <?xml version="1.0" encoding="utf-8&qu…