欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

最小生成樹算法之Prim算法

 更新時間:2015年07月23日 10:53:01   作者:砍柴1990  
這篇文章主要講解了普里姆算法(Prim算法),圖論中的一種算法,可在加權連通圖里搜索最小生成樹,需要的朋友可以參考下

本文介紹了最小生成樹的定義,Prim算法的實現(xiàn)步驟,通過簡單舉例實現(xiàn)了C語言編程。

1.什么是最小生成樹算法?
簡言之,就是給定一個具有n個頂點的加權的無相連通圖,用n-1條邊連接這n個頂點,并且使得連接之后的所有邊的權值之和最小。這就叫最小生成樹算法,最典型的兩種算法就是Kruskal算法和本文要講的Prim算法。

2.Prim算法的步驟是什么?
這就要涉及一些圖論的知識了。
a.假定圖的頂點集合為V,邊集合為E.
b.初始化點集合U={u}.//u為V中的任意選定的一點
c.從u的鄰接結點中選取一點v使這兩點之間的權重最小,然后將v加入集合U中.
d.從結點v出發(fā),重復c步驟,直到V={}.

3.舉個例子來說明Prim算法的步驟:
一個簡單的加權拓撲圖如下所示

選取1為初始點,則按照上面所示的步驟訪問結點的順序依次次為:

則最終訪問結點的順序:1,3,4,2,5.
4.Prim算法的具體C語言編程實現(xiàn):

#include <stdio.h>
#include <cstdlib>
#include<memory.h>
const int Max =0x7fffffff;
const int N=50;
 
int n;
int g[N][N],dis[N],visited[N];
 
int prim()
{
  int i,j;
  int pos,min;
  int ans=0;
  memset(visited,0,sizeof(visited));
  visited[1]=1;pos=1;
  //assign a value to the dis[N] first
  for(i=2;i<=n;i++)
    dis[i]=g[pos][i];
  for(i=1;i<n;i++)
  {
    min=Max; 
    for(j=1;j<=n;j++)
    {
      if(visited[j]==0&&min>dis[j])
      {
        min=dis[j];
        pos=j; 
      }
    }
    printf("The node being traversed is :%d\n",pos);
    ans+=min;
    printf("The value of ans is %d\n",ans);
    //mark the node
    visited[pos]=1;
    //update the weight
    for(j=1;j<=n;j++)
      if(visited[j]==0&&dis[j]>g[pos][j])
        dis[j]=g[pos][j];
  }
  return ans;
}
 
int main()
{
  int i=1,j=1;
  int ans=0;
  int w;
  printf("Please enter the number of the nodes:\n");
  scanf("%d",&n);
  for(i=1;i<=n;i++)
    for(j=1;j<=n;j++)
    {
      if(i==j)
        g[i][j]=0;
      else
        g[i][j]=Max;
    }
  printf("Please enter the number of the edges:\n");
  int edgenum;
  scanf("%d",&edgenum);
  int v1,v2;
  printf("Please enter the number and the corresponding weight:\n");
  for(i=1;i<=edgenum;i++)
  {
    scanf("%d%d%d",&v1,&v2,&w);
    g[v1][v2]=g[v2][v1]=w;
  }
  ans=prim();
  printf("The sum of the weight of the edges is:%d\n",ans);
  system("pause");
  return 0;
   
}

5.程序運行后的結果截圖

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。

相關文章

  • C++獲得本機所有網(wǎng)卡的IP和MAC地址信息的實現(xiàn)方法

    C++獲得本機所有網(wǎng)卡的IP和MAC地址信息的實現(xiàn)方法

    下面小編就為大家?guī)硪黄狢++獲得本機所有網(wǎng)卡的IP和MAC地址信息的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • C語言庫的封裝和使用方法總結

    C語言庫的封裝和使用方法總結

    在編程的過程中,使用已經(jīng)封裝好的庫函數(shù)是十分方便的,也是十分高效的,這篇文章主要給大家介紹了關于C語言庫的封裝和使用的相關資料,需要的朋友可以參考下
    2021-07-07
  • C++實現(xiàn)馬踏棋盤(騎士周游)

    C++實現(xiàn)馬踏棋盤(騎士周游)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)馬踏棋盤,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C語言實現(xiàn)斗地主的核心算法

    C語言實現(xiàn)斗地主的核心算法

    本文給大家分享的是使用C語言實現(xiàn)的斗地主游戲的核心算法,主要實現(xiàn)了面向?qū)ο笤O計,洗牌、發(fā)牌、判斷牌型、比較牌的大小、游戲規(guī)則等算法。通過這個斗地主小項目的練習,提高了我的面向?qū)ο笤O計能力,加深了對算法的理解。最近把這些設計和算法分享給大家。
    2015-03-03
  • C++實現(xiàn)順序表的常用操作(插入刪出查找輸出)

    C++實現(xiàn)順序表的常用操作(插入刪出查找輸出)

    實現(xiàn)順序表的插入,刪除,查找,輸出操作在C語言中經(jīng)常用到。下面小編給大家整理實現(xiàn)代碼,一起看下吧
    2016-08-08
  • C語言算法練習之抓交通肇事犯

    C語言算法練習之抓交通肇事犯

    這篇文章主要該大家分享C語言算法抓交通肇事犯的練習,文章主要通過描述抓交通肇事犯得問題然后確定程序框架將結果運算出來,下面來看詳細內(nèi)容吧,需要的朋友可以參考一下
    2022-03-03
  • C語言 makefile學習及實現(xiàn)實例

    C語言 makefile學習及實現(xiàn)實例

    這篇文章主要介紹了C語言 makefile學習及實現(xiàn)實例的相關資料,需要的朋友可以參考下
    2017-03-03
  • C++詳解如何實現(xiàn)動態(tài)數(shù)組

    C++詳解如何實現(xiàn)動態(tài)數(shù)組

    這篇文章主要為大家詳細介紹了C++實現(xiàn)動態(tài)數(shù)組的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C++用兩個棧實現(xiàn)一個隊列(面試官的小結)

    C++用兩個棧實現(xiàn)一個隊列(面試官的小結)

    這篇文章主要給大家介紹了關于C++用兩個棧實現(xiàn)一個隊列的相關資料,這是來自一名面試官的小結,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C++具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05
  • C++通過msxml調(diào)用webservice示例分享

    C++通過msxml調(diào)用webservice示例分享

    這篇文章主要介紹了C++通過msxml調(diào)用webservice示例分享,需要的朋友可以參考下
    2014-03-03

最新評論