【C++學習筆記】 鏈式前向星

来源:https://www.cnblogs.com/cTz2o7pN/archive/2018/09/01/9562800.html
-Advertisement-
Play Games

鏈式前向星是一種常見的儲存圖的方式(是前向星存圖法的優化版本),支持增邊和查詢,但不支持刪邊(如果想要刪除指定的邊建議用鄰接矩陣)。 儲存方式 首先定義數組 head[ i ] 來儲存從節點 i 出發的第一條邊的下標,定義結構體 edge[ i ] 中包含三個元素 nxt, to, val, 分別儲 ...


 鏈式前向星是一種常見的儲存圖的方式(是前向星存圖法的優化版本),支持增邊和查詢,但不支持刪邊(如果想要刪除指定的邊建議用鄰接矩陣)。

  • 儲存方式

  首先定義數組 head[ i ] 來儲存從節點 i 出發的第一條邊的下標,定義結構體 edge[ i ] 中包含三個元素 nxt, to, val, 分別儲存從節點 i 出發的下一條邊的下標(nxt),該邊的終點(to), 該邊的邊權(val)。

1 struct EDGE {
2     int nxt, to, val;    /* 下一條邊的下標, 這條邊的終點, 邊權 */ 
3 };
4 EDGE edge[maxn];
5 
6 int head[maxn];   /* head[ i ]儲存從節點 i 出發的第一條邊的下標 */
  • 添加節點

  定義變數 cnt 表示當前邊的編號(初始值為0),具體如代碼所示。

 1 int cnt = 0;
 2 
 3 void add ( int st, int ed, int v ) {
 4     edge[ ++cnt ].nxt = head[st];
 5     edge[cnt].to = ed;
 6     edge[cnt].val = v;
 7     head[st] = cnt;
 8 
 9 /*    
10     edge[ ++cnt ].nxt = head[ed];    * 如果是無向圖就加上這個語句 
11     edge[cnt].to = st; 
12     edge[cnt].val = v;
13     head[ed] = cnt;
14 
15 */
16 
17 }
  • 節點的遍歷

  從數據結構就可以看出來,上代碼。

1 /* i 是作為原點的節點編號 */
2 for ( int j = head[i]; j != 0 ; j = edge[j].nxt )  /* <-- 鏈式前向星遍歷的關鍵 */
3         printf ( "-->%d || val = %d \n", edge[j].to, edge[j].val );
4     }
  • 彙總代碼
 1 #include <cstdio>
 2 #include <cstring>
 3 
 4 using namespace std;
 5 
 6 const int maxn = 2018702;
 7 
 8 struct EDGE {
 9     int nxt, to, val;    /* 下一條邊的下標, 這條邊的終點, 邊權 */ 
10 };
11 EDGE edge[maxn];
12 
13 int head[maxn], cnt = 0; /* head[ i ]儲存從節點 i 出發的第一條邊的下標 */
14 
15 void add ( int st, int ed, int v ) {
16     edge[ ++cnt ].nxt = head[st];
17     edge[cnt].to = ed;
18     edge[cnt].val = v;
19     head[st] = cnt;
20 
21 /*    
22     edge[ ++cnt ].nxt = head[ed];    * 如果是無向圖就加上這個語句 
23     edge[cnt].to = st; 
24     edge[cnt].val = v;
25     head[ed] = cnt;
26 
27 */
28 
29 }
30 
31 int main () {
32     memset ( head, 0, sizeof head );
33     int n, m;
34     scanf ( "%d%d", &m, &n ); /* 共有 m 個節點, n 條邊 */
35     for ( int i = 1; i <= n; i ++ ){
36         int a, b, c;
37         scanf ( "%d%d%d", &a, &b, &c );
38         add ( a, b, c );
39     }
40     for ( int i = 1; i <= m; i ++ ){
41         printf ( "開始以節點%d為原點\n", i );
42         for ( int j = head[i]; j != 0 ; j = edge[j].nxt ) /* <-- 鏈式前向星遍歷的關鍵 */
43         printf ( "-->%d || val = %d \n", edge[j].to, edge[j].val );
44     }
45     return 0;
46 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 寫在前面 作為一個剛步入職場工作的新人,對於公司中所用的技術和框架基本上不懂,只能從最基礎的開始做起,進入公司接觸的第一個框架就是前端框架Vue.js,幾個功能做下來,覺得Vue.js首先學習起來真的非常簡單,用起來也是非常的方便,通過儘可能簡單的 API 實現響應的數據綁定和組合的視圖組件。它不僅 ...
  • .巨集任務(macrotask )和微任務(microtask ) macrotask 和 microtask 表示非同步任務的兩種分類。 在掛起任務時,JS 引擎會將所有任務按照類別分到這兩個隊列中,首先在 macrotask 的隊列(這個隊列也被叫做 task queue)中取出第一個任務,執行完畢 ...
  • 源碼可以到GitHub上下載! sessionStorage: 關閉瀏覽器再打開將不保存數據 複製標簽頁會連同sessionStorage數據一同複製 複製鏈接地址打開網頁不會複製seessionStorage內的數據 清除緩存載入當前頁對頁面無影響 1) 同源策略限制。若想在不同頁面之間對同一個s ...
  • 源碼可以到GitHub上下載! JS操作cookies方法 : 1.cookie若不設置過期時間關閉瀏覽器後會自動清除數據 2.存儲限制4k 3.同地址下其他文件也能讀取到 cookie用字元串拼接即可 cookie後可接 ; path=path ; domain=domain ; secure 1 ...
  • 地址:http://127.0.0.1:8082/prosperleedir/index.html?id=6666&name=prosper#prosper Location{ assign:ƒ (), // 載入新的文檔。 hash:"#prosper", // 設置或返回從井號 (#) 開始的 ...
  • webpack打包工具現在非常流行,熟悉並且能夠進行配置也變得非常重要。在學習和使用的過程中遇到過很多的問題,希望能夠讓自己記錄下來,鞏固自己的學習。 1.創建文件目錄 先在自己的常用盤中(我自己的項目一般都建在E盤的一個文件夾下)創建一個文件夾,比如webpack_demo,我用的編輯器是visu ...
  • Java是一種強類型語言。通俗說就是,在Java中存儲的數據都是有類型的,而且必須在編譯時就確定其類型。 編程規範里,也強調數據要有明確的數據類型。這樣會讓代碼變得很清晰,而且會規避不必要的麻煩。 ...
  • 題意 題目描述的很清楚。。。 有一天,貝茜無聊地坐在螞蟻洞前看螞蟻們進進出出地搬運食物.很快貝茜發現有些螞蟻長得幾乎一模一樣,於是她認為那些螞蟻是兄弟,也就是說它們是同一個家族裡的成員.她也發現整個螞蟻群里有時只有一隻出來覓食,有時是幾隻,有時乾脆整個蟻群一起出來.這樣一來,螞蟻們出行覓食時的組隊方 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...