課程設計 問題 R: 自來水管道

来源:http://www.cnblogs.com/mwtt/archive/2017/06/22/7062359.html
-Advertisement-
Play Games

題目描述 你領到了一個鋪設校園內自來水管道的任務。校園內有若幹需要供水的點,每兩個供水點可能存在多種鋪設路徑。對於每一種鋪設路徑,其成本是預知的。 任務要求最終鋪設的管道保證任意兩點可以直接或間接的聯通,同時總成本最低。 你領到了一個鋪設校園內自來水管道的任務。校園內有若幹需要供水的點,每兩個供水點 ...


題目描述

  

你領到了一個鋪設校園內自來水管道的任務。校園內有若幹需要供水的點,每兩個供水點可能存在多種鋪設路徑。對於每一種鋪設路徑,其成本是預知的。

 

    任務要求最終鋪設的管道保證任意兩點可以直接或間接的聯通,同時總成本最低。

輸入

每個測試用例由多行組成,第一行是兩個整數P和R,P代表供水點數(1<=P<=50),每個點都對應1到P中的一個唯一編號。R代表可能的鋪設路徑數,路徑數可能有非常多。接下有R行,每行格式如下:

節點A編號 節點B編號 路徑成本

路徑成本不超過100。

測試用例之間有一空行分開。輸入結束用P=0表示,註意沒有R值。

輸出

    每個測試用例占用一行輸出最低總成本。

樣例輸入

1 0

2 3
1 2 37
2 1 17
1 2 68

3 7
1 2 19
2 3 11
3 1 7
1 3 5
2 3 89
3 1 91
1 2 32

5 7
1 2 5
2 3 7
2 4 8
4 5 11
3 5 10
1 5 6
4 2 12

0

樣例輸出

0
17
16
26


題意:P個點,給出兩個點間的間的距離,求最小生成樹所需的成本。
思路:克魯斯卡爾演算法。將給出的邊按權值進行排序,遍歷所有的邊,如果該邊的兩個頂點不連通,則加入到生成樹中。
用sort函數排序權值。關鍵在於判斷該兩點是否連通。我用了並查集的思想。若兩點聯通則將一點的終節點指向另一點的終節點(用了數組b來存,b[i]就表示節點i指向的下一個節點)。
先初始化,讓b[i]=i。用自定義函數f(i)求i節點的終節點。如果兩節點a,b的f(a)和f(b)不想等。說明a,b,兩節點不連通。



#include<cstdio>
#include<algorithm>
using namespace std;
typedef struct
{
    int v[3];
} p;                   //用來存兩個供水點和之間的距離
bool comp(p a, p b)    //按v[2]中的元素進行比較
{
    return a.v[2] < b.v[2];
}
p a[10000005];
int b[105];
int f(int i)          //尋找終節點
{
    if(b[i]==i) return i;
else return f(b[i]); //應該可以優化成 return b[i]=f(b[i]); } int main() { int i,t,n,s,j; while(scanf("%d",&n)==1&&n) { s=0; scanf("%d",&t); for(i=1; i<=t; i++) scanf("%d%d%d",&a[i].v[0],&a[i].v[1],&a[i].v[2]); sort(a,a+t,comp); for(i=1; i<=n; i++) b[i]=i; for(i=1; i<=t; i++) { if(f(a[i].v[0])!=f(a[i].v[1])) //如果不連通就加入生成樹中並累加路徑 { s+=a[i].v[2]; b[f(a[i].v[0])]=f(a[i].v[1]); //將一點的終節點指向另一點的終節點 } } printf("%d\n",s); } return 0; }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文目錄: 10.1 /proc的意義及說明 10.2 查看進程信息 10.2.1 pstree命令 10.2.2 ps命令 10.2.3 ps後grep問題 10.2.4 top、htop以及iftop命令 10.3 vmstat命令 10.4 iostat命令 10.5 sar命令 10.5.1 ...
  • 本文目錄: 9.1 進程的簡單說明 9.11 進程和程式的區別 9.12 多任務和cpu時間片 9.13 父子進程及創建進程的方式 9.14 進程的狀態 9.15 舉例分析進程狀態轉換過程 9.16 進程結構和子shell 9.2 job任務 9.3 終端和進程的關係 9.4 信號 9.41 需知道 ...
  • 學習網址:http://c.biancheng.net/cpp/html/2728.html 1.在當前目錄下添加多重文件夾: ...
  • 您有這樣的牢騷麽? 有一周沒更新博客了,簡單說下在乾什麼吧;主要是公司安排對接某旅游大公司的介面,介面數量倒也就10個左右,對接完後還需要加入到業務系統中和App端,因此還是需要花點時間的;時間上來說業務需求安排在6月最後一周上線,整個3周的時間,就本人一人負責,由於在這之前對接過另外一個公司介面, ...
  • 我們接著上一篇文章進行講解 http://www.cnblogs.com/songjianhui/p/7060698.html 一:客戶端通過添加引用調用服務 WCF應用服務被成功寄宿後,WCF服務應用便開始了服務調用請求的監聽工作。此外,服務寄宿將服務描述通過元數據的形式發佈出來,相應的客戶端就可 ...
  • 本節詳細討論和分析一些常見的正則表達式,包括郵編、日期和時間、手機和固定電話、身份證、Email地址、IP地址、URL和中文字元。 ...
  • 原理是這樣的 svn伺服器一般放在公共的伺服器上,大家連這個伺服器,在MyEclipse上使用svn控制項 可以下載svn上的項目至本地,所以很多公司將開發要用到的軟體都放在svn上,有同事來只要連上svn 就可以把需要的東西下下來了1.update更新更新,是指 伺服器上變動了的 而你本地沒有變動,... ...
  • IOC(Inverse of Control)控制反轉 Java即生活,鄙人的感悟. 好比我們需要租房.現在我們房源不需要找到某個具體的房東(new fangdong() 房東對象才能租他的房 fangdong.rent()).如果我們對這個房東的房源不滿意,離地鐵太遠了.....heh.我們還需要 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...