圖的基本概念【數據結構】

序言
1對1的線性結構,一對多的樹二叉樹以及森林,第3種就是多對多的結構,也就是我們所要講到的圖的結構,圖形結構是數據結構當中最復雜的一種結構,圖形結構的特點就是在這個圖當中任意兩點之間都會有關系,這里的關系指的是可能會有關系,因為不是一對多也不是1對1,所以沒有辦法區分層次和順序了,圖上的頂點與頂點之間,我們可以認作是平等的,那我們如何去描述圖形結構?
在這里我們會提到兩個概念,一個是頂點集,一個是弧集,在這里要區分弧跟邊兒的概念,
對于前面1對1和一對多的關系,我們是可以用數據來進行描述它們之間的關系的,也很方便找到他們的前驅和后繼,1對1或者是一對多的關系,他們之間的數據與數據之間都有一定的關系,找到某一個數據之后,另外的數據就可以根據前一個數據進行推導出來,和我們現在所提到的圖的結構是有區別的,圖的結構在描述數據與數據之間的關系時,所采用的描述方式包括了邊兒,邊兒的方向決定了數據與數據之間存在怎樣的關系,那為什么說描述不了圖形之間的關系?因為圖形當中點和點之間的關系是不確定的,他們沒有一個確定的關系,并不像樹形結構一樣,可以看作是一個家族家族之間存在血緣關系,但是對于圖來說點和點之間是沒有血緣關系的,
【1】根據圖形結構,我們能夠想到哪些個東西?
圖形結構就是把沒有關系的點和點之間通過一些個輔助條件轉化成為一種有關系的結構,只有當輔助條件相當多的時候,我們才能夠描述出圖形之間點和點之間各種數據關系
【2】圖的概念?
圖是有一個頂點及V和一個弧集R構成的數據結構
在這里插入圖片描述弧描述了點與點之間的關系,是一條有效線段,起點為弧尾,終點為弧頭
有向圖在這里插入圖片描述此時a和b之間的關系是不相等的,是對于有象圖來說的,因為有象圖包含弧,也就是包含一條有向線段
無向圖
先提出的弧的概念,有弧推廣得到的邊的概念,若一根弧正向屬于弧,反過來也屬于弧,那么我們就概括為邊的概念
【1】相等:如果兩個點之間存在邊,那么我們就認為這兩個點之間的關系是平級的在這里插入圖片描述
相關術語在這里插入圖片描述在這里插入圖片描述
nlogn是我們人為規定的,我們根據需要來進行規定,拿些我們可以認為是稀疏圖,哪些我們認為是稠密的圖都是我們自己決定的在這里插入圖片描述我們注意:關聯是三者之間的一種關系,而不是點與點之間的一種關系,要包括他們之間的邊
我們在講哈弗曼樹的時候提到過路徑的概念,在這里插入圖片描述簡單回路是由簡單路徑組成的,不能出現重復的點----簡單回路是在簡單路徑中提出來的,具有基礎性質在這里插入圖片描述判斷聯通圖的方法?
點與點之間是有一條或多條邊連接在一起的,不能夠單獨拆開,如果拆開了,那就是聯通分量
對于有向圖來說,若任意兩個頂點之間都存在一條有向路徑,那么稱此有向圖為強連通圖簡單的來說就是有出度和入度

圖的生成樹

先說一種思想:
復雜的東西我們要往簡單的方向考慮,這樣我們的編碼生活才會更加的簡單-----復雜的東西簡單化但是我們解決復雜的東西我們要找到對應的關系,就像是我們想要馬拉松比賽,那么我們可以找到每一段對應的終點,將復雜的問題簡單化
生成樹是什么?
首先我們要知道生成樹是原圖的一個子圖,此圖的特性是包含原圖的所有頂點,以及其中的n-1條邊,這n-1條邊是從原來的一條邊開始進行尋找,通過n-1條邊能夠將原來的所有頂點連接到一起,形成一個連通子圖,所謂的聯通就是沒有孤立的點
問題:用到哪些特性了?
如果我們將n個頂點用n-1條邊連接起來,要把它作為聯通的圖,就一定不會出現回路,基本可以肯定的是他是一個樹形結構,不會存在圈兒,到每一個點有唯一一條線與它連接,因此引出了樹形結構,我們的樹形結構從下向上看,除了根節點,每一個頂點都有唯一一個指針指向他,我們試想一下,我們有5個點,如果我們用4條邊將5個點連接在一起,那么就不會出現回路的情況,三角形是有三個頂點,三條邊,正方形是有4個頂點,4條邊,當邊與頂點的數值相同的時候才會出現回路,
聯通圖才可以得到生成樹,
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

圖的存儲表示

我們知道存儲結構有兩大類,一類是順序結構,一類是鏈式結構,但是對于簡單的順序結構以及鏈式結構是不能夠滿足圖的存儲使用的,需要在此基礎上做出一些改變,在這里插入圖片描述圖的鄰接矩陣表示在這里插入圖片描述總結以下特點:
【1】:對于無向圖來說,鄰接矩陣就是對稱的,因為我們的線段是從兩個方向同時指出來的,那么我們就需要記錄兩個1,因此我們應該想到的是前面提到的三角矩陣
計算
有向圖的鄰接矩陣不一定是對稱矩陣在這里插入圖片描述我們如何計算頂點的出度以及入度?
首先我們應該找到節點所在的行,行上面的1代表的就是出度,列代表的是入度,總的度我們用出度加上入度來進行表示就可以了
圖上的矩陣數據表示的是邊或者弧,而不是表示的節點問題,因此我們在進行結點的刪除以及添加的時候,我們還是不方便的,原因是我們使用的是線性結構,而不是鏈式結構,因此下面我們將要介紹的就是鏈式結構在這里插入圖片描述有向圖是分為兩種的,一種是正向的,后面的連接是從小到大的,另外一種是反向的,對應的鏈接表時從大到小進行連接的在這里插入圖片描述

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

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

相關文章

go語言一天入門(上)

第一個go程序 package mainimport "fmt"func main() {/* 這是我的第一個簡單的程序 */fmt.Println("Hello, World!") } 第一行代碼 package main 定義了包名。你必須在源文件中非注釋的第一行指明這個文件屬于哪個包,如:package m…

Jquery 全選,反選

<script src"../js/jquery-1.6.2.min.js" type"text/javascript"></script><script language"javascript" type"text/javascript">$(function(){$("#selectAll").click(function(){//全選$("#playLi…

go語言一天入門(下)

結構體 和c一樣 package mainimport "fmt"type Books struct {title stringauthor stringsubject stringbook_id int }func main() {// 創建一個新的結構體fmt.Println(Books{"Go 語言", "www.runoob.com", "Go 語言教程", 6495407}…

圖的遍歷算法【數據結構F】

圖的遍歷算法有哪兩種&#xff1f; 深度優先調度算法---------將圖結構看成是樹形結構&#xff0c;樹形結構的子圖直接是沒有交叉的&#xff0c;但是對于圖結構的樹形結構之間是有交叉的&#xff0c;類比于樹形結構的二叉樹&#xff0c;左指數和右指數都會相應的經歷三次&#…

go語言快速刷《程序員面試金典》(1)

實現一個算法&#xff0c;確定一個字符串 s 的所有字符是否全都不同。 一個數組統計是否有 func isUnique(astr string) bool {var arr[26] int;for _,ch:range astr{num:ch-aif(arr[num]1){return false}arr[num]}return true } 給定兩個字符串 s1 和 s2&#xff0c;請編寫一…

最小生成樹【數據結構】

前提 【1】網的最小生成樹&#xff0c;涉及到生成樹了那么就會有最小的權值在里面了 【2】對于一個圖來說生成樹是由多個的&#xff0c;并不是唯一的 【3】&#xff1a;廣度優先算法的遍歷是可以得到生成樹的&#xff0c;深度優先算法也是可以得到生成樹的 任意的一個聯通網&am…

go語言快速刷《程序員面試金典》(2)

字符串輪轉。給定兩個字符串s1和s2&#xff0c;請編寫代碼檢查s2是否為s1旋轉而成&#xff08;比如&#xff0c;waterbottle是erbottlewat旋轉后的字符串&#xff09;。 示例1 輸入&#xff1a;s1 "waterbottle", s2 "erbottlewat" 輸出&#xff1a;T…

廣義表的基本概念【數據結構】

實名廣義表與匿名廣義表的區別&#xff1a;對于匿名的廣義表的表示方法我們認為一對括號就是一個廣義表&#xff0c;里面的數據可以是廣義表也可以是 原子&#xff0c;對于有名字的廣義表&#xff0c;也就是大寫的字母我們可以直接認為大寫的就是廣義表的表示方法小練習----廣義…

go語言快速刷《程序員面試金典》(3)

編寫程序以 x 為基準分割鏈表&#xff0c;使得所有小于 x 的節點排在大于或等于 x 的節點之前。如果鏈表中包含 x&#xff0c;x 只需出現在小于 x 的元素之后(如下所示)。分割元素 x 只需處于“右半部分”即可&#xff0c;其不需要被置于左右兩部分之間。 示例: 輸入: head …

樹和二叉樹【數據結構】

基本概念 ADT的定義 基本操作 對比樹形結構和線性結構 基本術語以及注意事項-不能錯誤簡單的我以為 二叉樹是度數小于等于2的樹&#xff0c;而不是度為2的樹&#xff0c;一定要記住這個概念 小知識&#xff1a;二進制轉換成為十進制的方法名稱叫做位權求和法&#xff0c;用到…

leetcode557. 反轉字符串中的單詞 III python,處理字符串的神!

給定一個字符串&#xff0c;你需要反轉字符串中每個單詞的字符順序&#xff0c;同時仍保留空格和單詞的初始順序。 示例 1: 輸入: "Lets take LeetCode contest" 輸出: "steL ekat edoCteeL tsetnoc" 注意&#xff1a;在字符串中&#xff0c;每個單詞由…

數據庫2.1.1mysql的特點

在mysql5.1當中&#xff0c;mysqlab公司引入了新的插件式存儲引擎體系結構&#xff0c;也許將存儲引擎加載到正在運行的mysql服務器當中&#xff0c;使用mysql插件是存儲引擎體系結構允許數據庫用戶為特定的應用需求選擇專門的存儲引擎&#xff0c;完全不需要管理任何特殊的應用…

leetcode369. 給單鏈表加一

用一個 非空 單鏈表來表示一個非負整數&#xff0c;然后將這個整數加一。 你可以假設這個整數除了 0 本身&#xff0c;沒有任何前導的 0。 這個整數的各個數位按照 高位在鏈表頭部、低位在鏈表尾部 的順序排列。 示例: 輸入: [1,2,3] 輸出: [1,2,4] 思路&#xff1a; hel…

MySQL常見的兩種存儲引擎:MyISAM與InnoDB的愛恨情仇

一 MyISAM 1.1 MyISAM簡介 MyISAM是MySQL的默認數據庫引擎&#xff08;5.5版之前&#xff09;&#xff0c;由早期的 ISAM &#xff08;Indexed Sequential Access Method&#xff1a;有索引的順序訪問方法&#xff09;所改良。雖然性能極佳&#xff0c;而且提供了大量的特性&a…

leetcode193. 有效電話號碼 正則了解一下

給定一個包含電話號碼列表&#xff08;一行一個電話號碼&#xff09;的文本文件 file.txt&#xff0c;寫一個 bash 腳本輸出所有有效的電話號碼。 你可以假設一個有效的電話號碼必須滿足以下兩種格式&#xff1a; (xxx) xxx-xxxx 或 xxx-xxx-xxxx。&#xff08;x 表示一個數字…

leetcode258. 各位相加

給定一個非負整數 num&#xff0c;反復將各個位上的數字相加&#xff0c;直到結果為一位數。 示例: 輸入: 38 輸出: 2 解釋: 各位相加的過程為&#xff1a;3 8 11, 1 1 2。 由于 2 是一位數&#xff0c;所以返回 2。 進階: 你可以不使用循環或者遞歸&#xff0c;且在 O(…

leetcode412. Fizz Buzz

寫一個程序&#xff0c;輸出從 1 到 n 數字的字符串表示。 1. 如果 n 是3的倍數&#xff0c;輸出“Fizz”&#xff1b; 2. 如果 n 是5的倍數&#xff0c;輸出“Buzz”&#xff1b; 3.如果 n 同時是3和5的倍數&#xff0c;輸出 “FizzBuzz”。 示例&#xff1a; n 15, 返…

leetcode359. 日志速率限制器

請你設計一個日志系統&#xff0c;可以流式接收日志以及它的時間戳。 該日志會被打印出來&#xff0c;需要滿足一個條件&#xff1a;當且僅當日志內容 在過去的 10 秒鐘內沒有被打印過。 給你一條日志的內容和它的時間戳&#xff08;粒度為秒級&#xff09;&#xff0c;如果這…

怎樣提高WebService性能大數據量網絡傳輸處理(轉)

1. 直接返回DataSet對象 特點&#xff1a;通常組件化的處理機制&#xff0c;不加任何修飾及 處理&#xff1b; 優點&#xff1a;代碼精減、易于處理&#xff0c;小數據量處理較快&#xff1b; 缺點&#xff1a;大數據量的傳遞處理慢&#xff0c;消耗網絡資源&#xff1b; 建議&…

【中國互聯網江湖30年歷史】再無風清揚,再有少年郎

0 馬云退了。 在蕭山奧體中心&#xff0c;無數阿里人的祝福中&#xff0c;流著眼淚&#xff0c;結束了自己在阿里的最后一天。 從此互聯網江湖再無風清揚&#xff0c;反而多了一個叫做馬云的鄉村教師。 他臨別一揮手&#xff0c;似乎帶走了中國互聯網的一個時代。 20年浮沉&…