最小連通-(代碼、分析、匯編)

目錄:

    • 介紹:
    • 代碼:
    • 分析:
    • 匯編:

介紹:

一個有 n 個結點的連通圖的生成樹是原圖的極小連通子圖,且包含原圖中的所有 n 個結點,
并且有保持圖連通的最少的邊。
最小生成樹可以用kruskal(克魯斯卡爾)算法或prim(普里姆)算法求出

普利姆算法,圖論中一種算法,可在加權連通圖里搜索最小生成樹。
此算法搜索到的邊子集所構成的樹中,不但包括連通圖里的所有頂點,且所有邊的權值最小

代碼:

#include <stdio.h>
#include <stdlib.h>/*
程序描述:
矩陣有多行數據,cost數組從矩陣中提取數據,P記錄cost數組的數據分別屬于矩陣的哪一行
Mark記錄在cost不再進行比較數據的下標(已經是最小值當前cost中最小值的下標了)
在cost數組中找出最小值與其在cost中的下標,再將該下標在mark中標記,下次不再處理這個位置
當前cost比較完成后,用找到的最小值作為下一行要提取數據的行號,然后用該行的數據與cost中的數據
比較,取每個位置較小值,除了已經標記的位置不進行提取。并修改P中對應較小值屬于行
更新cost和P后,再進行在cost中找最小值同樣的操作,依次循環整個矩陣
*/#define VNUM 9
#define MV 65536int P[VNUM];//存儲要當前比較的數據是屬于哪一行的
int Cost[VNUM];//要用于比較的數據的數組
int Mark[VNUM];//記錄列狀態,標記為1的列,將不再處理比較
int Matrix[VNUM][VNUM] =    //n行與n列數據一樣的矩陣
{{0, 10, MV, MV, MV, 11, MV, MV, MV},{10, 0, 18, MV, MV, MV, 16, MV, 12},{MV, 18, 0, 22, MV, MV, MV, MV, 8},{MV, MV, 22, 0, 20, MV, MV, 16, 21},{MV, MV, MV, 20, 0, 26, MV, 7, MV},{11, MV, MV, MV, 26, 0, 17, MV, MV},{MV, 16, MV, MV, MV, 17, 0, 19, MV},{MV, MV, MV, 16, 7, MV, 19, 0, MV},{MV, 12, 8, 21, MV, MV, MV, MV, 0},
};
//cost 先取第一行的數據開始比較
void Prim(int sv) // O(n*n)
{int i = 0;int j = 0;if( (0 <= sv) && (sv < VNUM) )//判斷sv在矩陣范圍內{for(i=0; i<VNUM; i++){Cost[i] = Matrix[sv][i];//將sv行所有列賦到cost,表示從sv行的數據開始處理比較P[i] = sv;//將P全部賦0,表示當前所有數據屬于0行的Mark[i] = 0;//Mark數組全賦0,初始化}Mark[sv] = 1;//將0列設為1,剛開始0列不處理比較for(i=0; i<VNUM; i++){int min = MV;int index = -1;for(j=0; j<VNUM; j++){//從沒有被標記數據中取值,找出cost(當前要比較的數據)中最小值和其在cost中的下標if( !Mark[j] && (Cost[j] < min) ){min = Cost[j];//給最小值賦值  index = j;//最小值的下標  }}if( index > -1 )//表示執行了上面,找到了最小值{Mark[index] = 1;  //將該下標進行標記,下次不再比較該列的數據printf("(%d, %d, %d)\n", P[index], index, Cost[index]); // 輸出這次查找出最小值位于的行與下標與數值}for(j=0; j<VNUM; j++) //循環找出下一次用比較的數據{//從上次找到的最小值的下標,作為重新提取數據的行//只要不是被標記的列,從行中提取的數據比原來比較的數據小就取行中的數和下標//也用新的一行中的數據與本來用于比較的數據取對應位置較小的一方,并將該位置的值屬于//哪一行中提取出來的,存到P中if( !Mark[j] && (Matrix[index][j] < Cost[j]) ) //更新到cost數組{Cost[j]  = Matrix[index][j];//更新用來比較數據數組P[j] = index;//更新數據屬于的行}}}}
}int main(int argc, char *argv[]) 
{Prim(0);getchar();return 0;
}

分析:

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

匯編:

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

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

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

相關文章

toad dba for oracle 10.5

http://worlddownloads.quest.com.edgesuite.net/Repository/support.quest.com/Toad%20for%20Oracle/10.5/Software/Toad%20DBA%20Suite%20for%20Oracle%2010.5%20Commercial.exe轉載于:https://www.cnblogs.com/devbar/archive/2010/07/01/1768986.html

c++ 怎樣連接兩個鏈表_LeetCode | 鏈表的入口,一文幫你搞定“環形鏈表”(python版,最簡單解析)...

鏈表節點的定義鏈表作為一種數據結構&#xff0c;由鏈表節點互相連接構成。鏈表節點包含自身的數據和一個指向下一節點的指針。""" Definition of ListNode """ class ListNode(object):def __init__(self, val, nextNone):self.val valself.ne…

QI實例-改變空間參考

學習AE一段時間了&#xff0c;總是對QI不是很理解&#xff0c;今天一晚上寫了QI實例&#xff0c;嘗試理解下。 首先想到的是→改變空間參考→alter、SpatialReference→alterSpatialReference&#xff0c;輸入到幫助文檔里。  查看是IGeoDatasetSchemaEdit接口的方法&#xf…

VeryCD 的資料庫

呵呵&#xff0c;剛才看了下VeryCD的資料庫&#xff0c;恍然間才明白為什么VeryCD以前花大量時間和精力開發電驢&#xff0c;又為什么不久前突然取消了KAD網絡和ED2k網絡的搜索功能。呵呵&#xff0c;天下沒有免費的午餐哈&#xff0c;VeryCD先用電驢軟件聚集客戶群&#xff08…

Java IdentityHashMap keySet()方法及示例

IdentityHashMap類keySet()方法 (IdentityHashMap Class keySet() method) keySet() method is available in java.util package. keySet()方法在java.util包中可用。 keySet() method is used to get a set of all the existing keys in this IdenityHashMap to be viewed in …

C#省市二級聯動(王者榮耀挑選英雄為例)

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms;namespace beyond_聯動_ {public partial clas…

二叉排序樹(Binary Sort Tree) 又稱為二叉查找樹(Binary Search Tree) - (代碼、分析)

目錄&#xff1a;代碼&#xff1a;分析&#xff1a;代碼&#xff1a; BSTree.h #ifndef _BSTREE_H_ #define _BSTREE_H_typedef void BSTree;//定義二叉樹類型 typedef void BSKey;//定義節點的鍵值類型&#xff08;用于節點排序&#xff09;typedef struct _tag_BSTreeNode …

springboot tomcat默認線程數_記一次JAVA線程池的錯誤用法

最近項目一個項目要結項了&#xff0c;但客戶要求 TPS 能達到上千&#xff0c;而用我寫的代碼再怎么弄成只能達到 30 的 TPS&#xff0c;然后我又將代碼中能緩存的都緩存了&#xff0c;能拆分的也都拆分了&#xff0c;拆分時用的線程池來實現的&#xff1b;其實現的代碼主要為…

引以為鑒-ARM開發板連線注意事項

前些日子把實驗室的三臺機子放到一個工位上&#xff0c;非常擁擠&#xff0c;做實驗也很不方便。因此&#xff0c;想把ARM開發板的環境重新搭建到自己的電腦上。說完就做&#xff0c;上午就開始忙活起來。把開發板上的USB線、串口線、JTAT接口、還有電源線一一插好。接著就開始…

CString 類型和引用

怎么理解CString & 類型&#xff1f;在函數參數表中&#xff0c;列了一項是此類型&#xff0c;據說是引用。可以給個具體方法&#xff0c;示例么&#xff1f; 由于子程序調用是棧傳遞參數&#xff0c;因此對參數的修改不會改變調用者傳入的參數的值。如果要改變調用者的參數…

Java IdentityHashMap putAll()方法與示例

IdentityHashMap類putAll()方法 (IdentityHashMap Class putAll() method) putAll() method is available in java.util package. putAll()方法在java.util包中可用。 putAll() method is used to copy all of the entry (key-value pairs) that exists from the given map (m)…

Python---實驗八

1&#xff0c;現在有一份‘邀請函.txt’的空白文件&#xff0c;請在同級目錄下編寫一段代碼&#xff0c;寫入內容‘誠摯邀請您來參加本次宴會’。 with open(fG:\study\Python\邀請函.txt,modew,encodingutf-8) as y:y.write(誠摯邀請您來參加本次宴會)效果圖如下&#xff1a;…

哈希表 - (代碼、分析 )

目錄&#xff1a;代碼&#xff1a;分析&#xff1a;代碼&#xff1a; BSTree.h BSTree.c 二叉排序樹(Binary Sort Tree) 又稱為二叉查找樹(Binary Search Tree) Hash.h #ifndef _HASH_H_ #define _HASH_H_typedef void Hash;//定義哈希表類型 typedef void HashKey;//定義哈…

scala spark 數據對比_IT大牛耗時三個月總結出大數據領域學習路線,網友評論:炸鍋了...

大數據不是某個專業或一門編程語言&#xff0c;實際上它是一系列技術的組合運用。有人通過下方的等式給出了大數據的定義。大數據 編程技巧 數據結構和算法 分析能力 數據庫技能 數學 機器學習 NLP OS 密碼學 并行編程雖然這個等式看起來很長&#xff0c;需要學習的東…

Java IdentityHashMap equals()方法與示例

IdentityHashMap類equals()方法 (IdentityHashMap Class equals() method) equals() method is available in java.util package. equals()方法在java.util包中可用。 equals() method is used to check whether this IdentityHashMap object and the given object (ob) are eq…

jQuery中關于Ajax的詳解

本文介紹如何使用jquery實現Ajax功能. 用于發送Ajax請求的相關函數如load, get, getJSON和post這些漸變Ajax方法, 對于核心的ajax 方法沒有過多介紹, 主要是通過配置復雜的參數實現完全控制Ajax請求。 Ajax讓用戶頁面豐富起來, 增強用戶體驗. Ajax是所有Web開發的必修課. 雖然A…

Python---實驗九作業

1&#xff0c;使用tkinter實現計算器程序。實現效果如下&#xff1a; from tkinter import * from tkinter.ttk import *def frame(master):"""將共同的屬性作為默認值, 以簡化Frame創建過程"""w Frame(master)w.pack(sideTOP, expandYES, fill…

分析FLV文件分析和解析器的開源代碼

分析一下GitHub上一份FLV文件分析和解析器的開源代碼 GitHub源碼地址&#xff1a;功能強大的 FLV 文件分析和解析器 &#xff1a;可以將flv文件的視頻tag中的h264類型數據和音頻tag中的aac類型數據導出 &#xff08;只限h264和aac&#xff09; (這個代碼不太適合用于大文件的分…

用pv操作描述如下前驅圖_LinkedList實現分析(二)——常用操作

上一篇文章LinkedList實現分析(一)——LinkedList初探與對象創建介紹了LinkedList中的一些重要屬性和構造方法&#xff0c;下面我們將詳細介紹一下LinkedList提高的常用方法的實現原理元素添加###add(E e)方法往LinkedList添加元素&#xff0c;LinkedList提供了多重方式&#x…

C++多重繼承與虛基類及與.NET的比較

多重繼承前面我們介紹的派生類只有一個基類&#xff0c;稱為單基派生或單一繼承。在實際運用中&#xff0c;我們經常需要派生類同時具有多個基類&#xff0c;這種方法稱為多基派生或多重繼承。2.1 多重繼承的聲明&#xff1a;在 C 中&#xff0c;聲明具有兩個以上基類的派生類與…