第六章學習小結

? ? ? 本章學習了圖的結構及應用,

? ? ? 首先是圖的分類,圖分為無向圖、有向圖、完全圖、連通圖、強連通圖、帶權圖、稀疏圖、稠密圖等等。

? ? ? 圖的存儲方式有兩大類,以邊集合方式的表示法和以鏈接方式的表示法。其中,以邊集合方式表示的為鄰接矩陣(借助二維數組來表示元素之間的關系,實現較為簡單),以鏈接方式表示的包括鄰接表、十字鏈表和鄰接多重表(屬于鏈式存儲結構,實現較為復雜)。

? ? ? 接下來是圖的遍歷算法,圖的遍歷算法有兩種,包括深度優先搜索遍歷和廣度優先搜索遍歷。

? ? ? 深度優先搜索遍歷類似于樹的先序遍歷,借助于棧結構來實現。

void DFS(Graph a,int b) //深度優先搜索 
  {visited[b]=true;    //令頂點對應的visited數組為true,表示該頂點已被訪問過 cout<<b<<" ";   //輸出頂點編號及空格 for(int i=0;i<a.vexnum;i++){if(a.arcs[b][i]==1 && visited[i]==false)DFS(a,i);   //若頂點對應的鄰接點未被訪問,則遞歸調用DFS函數 
      }}
DNF

? ? ? 廣度優先搜索遍歷類似于樹的層次遍歷,借助隊列結構來實現。

void BFS(Graph a,int b) //廣度優先搜索 
 {int temp;   //定義參數 while(!q.empty())   //若隊列不為空 
      {temp=q.front(); //取隊頭元素值為temp q.pop();    //隊頭元素出隊 
               cout<<temp<<" ";    //輸出temp值及空格 for(int i=0;i<a.vexnum;i++){if(a.arcs[temp][i]==1 && visited[i]==false) //若頂點對應的鄰接點未被訪問,則鄰接點入隊 
             {q.push(i);  //鄰接點入隊 visited[i]=true;    //鄰接點對應的visited數組取true,表示已被訪問 
             }}visited[b]=true;    //第一次入隊的頂點對應的visited數組值取true,表示已被訪問
     }}
BFS

? ? ? 然后是圖的應用,比較常用的包括構造最小生成樹算法、求解最短路徑算法

? ? ? 構造最小生成樹的算法有普里姆算法和克魯卡斯算法,其中

? ? ? 普里姆算法的核心是歸并點,時間復雜度是O(n2),適用于稠密網

? ? ? 克魯斯卡爾算法是歸并變,時間復雜度是O(elog2e),適用于稀疏網。

? ? ? 最短路徑算法包括迪杰斯特拉算法和弗洛伊德算法,其中

? ? ? 迪杰斯拉特算法是求從某個源點到其余各頂點的最短路徑,按路徑長度遞增的次序產生最短路徑,時間復雜度為O(n2)

? ? ? 弗洛伊德算法是求每一對頂點之間的最短路徑,時間復雜度為O(n3)

? ? ? 個人感覺圖這一章概念很多,算法也很多,要多花時間看書,弄懂書上的概念和算法。

?

轉載于:https://www.cnblogs.com/likangwenn/p/10891478.html

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

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

相關文章

大數據薪資一再飆升 學習大數據需要哪些基礎?

2018年6月19日&#xff0c;備受關注的個人所得稅法修正案草案迎來第七次大修&#xff0c;個稅起征點由每月3500元提高至每月5000元(每年6萬元)。對于大多數人來說這絕對是個好消息&#xff0c;但人們更愿意參加培訓班實現高薪。近年來&#xff0c;隨著互聯網的飛速發展以及企業…

idea 玩轉 碼云 -- idea安裝碼云插件

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 在git盛行的今天&#xff0c;碼云成為中國程序員的第二github&#xff0c;而且還可以免費使用私人空間。下面就開始碼云之旅吧。 0.創建…

阿里云的物聯網之路

阿里云的物聯網之路 作者 | 劉洪峰 責編 | 唐小引 本文首發于 CSDN 微信&#xff08;ID&#xff1a;CSDNnews&#xff09; 原文鏈接 未來十到二十年&#xff0c;大家基本已經形成了一個共識&#xff0c;那便是新格局的奠定將由 AI 和物聯網技術來支撐。放眼國內&#xff0c;在…

不是所有人都懂這樣做,你若做了就能高升!

有句話這樣說的&#xff0c;成功的人往往都是做著別人不愿意或不知道的事情&#xff0c;懂得付出才會獲得成功&#xff01; 同樣的道理&#xff0c;身在職場&#xff0c;每個人都有一種被提拔&#xff0c;晉升的愿望。 不過&#xff0c;光想著沒用&#xff0c;除了干好自身工…

面向對象-多態,反射

抽象父類 # 抽象父類&#xff1a;擁有抽象方法(子類共有的方法&#xff0c;但是父類不能有具體的實現體)的父類 # 抽象方法&#xff1a;方法名是具體的&#xff0c;但是實現體是抽象的(在子類中重寫來具象化) ? # 注意點&#xff1a;有抽象方法的父類不能被實例化&#…

解決 : Could not commit JPA transaction RollbackException: Transaction marked as rollbackOnly

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1. 報錯如題&#xff1a; RollbackException: Transaction marked as rollbackOnly 2. 原因是在一個事物 (Transaction) 中有另外一個…

yii2 migrate 數據庫遷移的簡單分享

開發中經常會用到的方法小結&#xff1a; 1、./yii migrate xxx_xx 在表中插入某字段 &#xff1a; public function up(){$this->addColumn({{application_service}}, auditor, INT(10) NOT NULL COMMENT "審核人" AFTER user_id, CHANGE COLUMN status status t…

養不教 父母之過:10個不能靠老師解決的孩子教育問題

1、寫字和握筆姿勢。 如果你經歷孩子成長的整個過程&#xff0c;你會感悟到&#xff0c;孩子寫一手帥氣的鋼筆字&#xff0c;是非常有價值的技能。把字寫好&#xff0c;是每一個家長的責任。如果你還年輕&#xff0c;不知道怎么教育孩子&#xff0c;那就從這一點開始吧。 記…

jpa : criteria 作排除過濾、條件中除去查出的部分數據、JPA 一個參數可查詢多個字段

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 PS &#xff1a; mybatis 中也有對于 criteria 的使用&#xff0c;見另一文章&#xff1a;mybatis &#xff1a;Criteria 查詢、條件過濾…

將你的前端應用打包成docker鏡像并部署到服務器?僅需一個腳本搞定

將你的前端應用打包成docker鏡像并部署到服務器&#xff1f;僅需一個腳本搞定1.前言前段時間&#xff0c;自己搞了個阿里云的服務器。想自己在上面折騰&#xff0c;但是不想因為自己瞎折騰而污染了現有的環境。畢竟&#xff0c;現在的阿里云已經沒有免費的快照服務了。要想還原…

CVPR2014: DeepID解讀

上周五就要發的&#xff0c;拖........拖.......拖到現在&#xff0c;文中有不準確的地方&#xff0c;歡迎批評指正。DeepID是一種特征提取的算法&#xff0c;由港中文湯曉鷗團隊于2014年提出&#xff0c;發表于CVPR2014。其應用領域是人臉識別的子領域——人臉驗證&#xff0c…

成大事必備9種能力 9種手段 9種心態(圖)

成大事必備9種能力 1、擺正心態&#xff0c;敢于面對現實 對于那些不停地抱怨現實惡劣的人來說&#xff0c;不能稱心如意的現實&#xff0c;就如同生活的牢籠&#xff0c;既束縛手腳&#xff0c;又束縛身心&#xff0c;因此常屈從于現實的壓力&#xff0c;成為懦弱者;而那些…

解決:A component required a bean of type ‘javax.jms.Queue‘ that could not be found.

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1. 情景描述&#xff1a;只是想簡單寫個 ActiveMQ 的小樣&#xff0c;啟動服務卻報錯&#xff1a; Error starting ApplicationContext…

【計算機視覺】OpenCV篇(3) - 圖像幾何變換(仿射變換/透視變換)

圖像的幾何變換從原理上看主要包括兩種&#xff1a;基于23矩陣的仿射變換&#xff08;平移、縮放、旋轉和翻轉等&#xff09;、基于33矩陣的透視變換。 仿射變換基本的圖像變換就是二維坐標的變換&#xff1a;從一種二維坐標(x,y)到另一種二維坐標(u,v)的線性變換&#xff1a; …

Linux學習第五篇之文件處理命令touch、cat、tac、more、less、head、tail

一、touch命令&#xff1a; 命令名稱&#xff1a;touch 命令所在路徑&#xff1a;/bin/touch 執行權限&#xff1a;所有用戶 語法&#xff1a;touch [文件名] 功能描述&#xff1a;創建空文件 例子&#xff1a; touch leanring.file 說明&#xff1a;在當前目錄下創建空文件l…

OpenCL 與 CUDA

根據網站資料&#xff0c;簡單地匯編一下CUDA與OpenCL的區別。如有錯誤請指出。 題外話&#xff1a; 美國Sandia國家實驗室一項模擬測試證明&#xff1a;由于存儲機制和內存帶寬的限制&#xff0c;16核、32核甚至64核處理器對于超級計算機來說&#xff0c;不僅不能帶來性能提升…

DBMS (數據庫管理系統) 是什么

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 數據庫管理系統&#xff08;英語&#xff1a;database management system&#xff0c;縮寫&#xff1a;DBMS&#xff09; 是一種針對對…

Eclipse4JavaEE安裝SpringBoot

第一步&#xff1a;下載SpringBoot SpringBoot官網下載鏈接 第二步&#xff1a;在Eclipse里進行安裝 打開Eclipse&#xff0c;菜單欄Help -》Install New Software&#xff0c;進入下圖界面&#xff0c;點擊Add 設置Name和Location&#xff0c;Name看自己喜好&#xff0c;Locat…

django中使用原生sql

django中使用原生sqlfrom django.db import connection cursor connection.cursor() cursor.execute("select * from xx where id1") row cursor.fetchone() users User.objects.raw("select * from user where namexx") for user in users: print(use…

從零開始玩轉 logback、完整配置詳解

官網地址&#xff1a;https://logback.qos.ch/manual/index.html 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 概述 LogBack是一個日志框架&#xff0c;它與Log4j可以說是同出一源&a…