洛谷 P3366 【模板】最小生成樹

来源:https://www.cnblogs.com/poi-bolg-poi/archive/2019/07/16/11197605.html
-Advertisement-
Play Games

[TOC] 題目 "戳" 思路 最小生成樹 "$\text{Prim}$和$\text{Kruskal}$" $Code$ $\text{Prim}$ cpp / Prim+鏈式前向星 / include define MAXN 5001 define inf 1061109567 using na ...


目錄


題目

思路

最小生成樹
$\text{Prim}$和$\text{Kruskal}$

$Code$

$\text{Prim}$

/*
Prim+鏈式前向星
*/
#include<bits/stdc++.h>
#define MAXN 5001
#define inf 1061109567
using namespace std;
int n,m,cnt,ans;
int dis[MAXN],head[MAXN];
bool vis[MAXN];
struct Edge{
    int next,to,w;
}edge[200001<<1];
inline int read(){
    int x=0;bool f=0;char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=!f;c=getchar();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
    return f?-x:x;
}
inline void addedge(int from,int to,int w){
    edge[++cnt].to=to,edge[cnt].next=head[from];
    edge[cnt].w=w,head[from]=cnt;
}
void Prim(){
    int tot=0,k=1;
    dis[1]=0;
    for(int i=head[1];i;i=edge[i].next){
        if(dis[edge[i].to]>edge[i].w)
            dis[edge[i].to]=edge[i].w;
    }
    while(++tot<n){
        int sum=0x7fffffff;
        vis[k]=1;
        for(int i=1;i<=n;++i){
            if(!vis[i]&&dis[i]<sum){
                k=i;
                sum=dis[i];
            }
        }
        ans+=sum;
        for(int i=head[k];i;i=edge[i].next){
            if(!vis[edge[i].to]&&dis[edge[i].to]>edge[i].w)
                dis[edge[i].to]=edge[i].w;
        }
    }
}

int main(){
    memset(dis,0x3f3f3f,sizeof(dis));
    n=read(),m=read();
    int u,v,w;
    while(m--){
        u=read(),v=read(),w=read();
        addedge(u,v,w),addedge(v,u,w);
    }
    Prim();
    for(int i=1;i<=n;++i){
        if(dis[i]==inf){
            printf("orz\n");
            return 0;
        }
    }
    printf("%d\n",ans);
    return 0;
}
/*
Prim+鄰接矩陣
*/
#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
#include<algorithm>
#define MAXN 5001
#define inf 1061109567
using namespace std;
int n,m,ans;
int map[MAXN][MAXN],dis[MAXN];
bool vis[MAXN];
inline int read(){
    int x=0;bool f=0;char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=!f;c=getchar();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
    return f?-x:x;
}
void Prim(){
    dis[1]=0;
    for(int i=1;i<=n;++i){
        int k=0;
        for(int j=1;j<=n;++j){
            if(!vis[j]&&dis[k]>dis[j]) k=j;
        }
        vis[k]=1;
        for(int j=1;j<=n;++j){
            if(!vis[j]&&map[k][j]<dis[j])
                dis[j]=map[k][j];
        }
    }
}

int main(){
    memset(map,0x3f3f3f,sizeof(map));
    memset(dis,0x3f3f3f,sizeof(dis));
    n=read(),m=read();
    int u,v,w;
    for(int i=1;i<=m;++i){
        u=read(),v=read(),w=read();
        if(map[u][v]>w){
            map[u][v]=w;
            map[v][u]=w;
        }
    }
    Prim();
    for(int i=1;i<=n;++i){
        ans+=dis[i];
        if(dis[i]==inf){
            printf("orz\n");
            return 0;
        }
    }
    printf("%d\n",ans);
    return 0;
}

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

-Advertisement-
Play Games
更多相關文章
  • eclipse 配置JDK_經驗 eclipse-->windows --> preformce-->java installed jre 然後要:--> change 再 rebuild 工程。 ...
  • 可以先想下這兩個問題: 1、怎樣使用滑動視窗? 2、如何快速的解決字元查重問題? 滑動視窗 可以想象一下有兩個指針,一個叫begin,一個叫now 這兩個指針就指定了當前正在比較無重覆的字元串,當再往後讀取一個字元的時候,就需要比較該字元在begin到now之間是否有重覆,如果有重覆的話,則記錄當前 ...
  • 溫故而知新 子曰:“溫故而知新,可以為師矣”。的確是這樣,對於技術知識的學習,我深有感悟。每一本書,每一個知識點,不去認真的讀上個2~3遍,根本無法理解其中的道理。藉著最近在學習SSH框架的機會,也抽時間把Java基礎知識好好再總結一遍,再系統的通過博文的形式將相關的知識樹,知識模塊總結出來。一來做 ...
  • 1. 函數的好處: 減少代碼重覆性(冗餘) 代碼可讀性高 將功能進行封裝(早工具) 2. 函數定義 3. 提示作用,沒有約束作用 4. 調用函數 函數名+() 多次調用就是執行多次 可以迴圈調用 5. 返回值 6. 參數 形參 函數定義的時候叫做形參 實參 傳參:將實參傳遞給形參的過程叫傳參 位置傳 ...
  • 相關素材下載 01.jsp 文件上傳UploadServlet.java 文件下載DownloadServlet.java web.xml ...
  • 總結 1.語法上和函數類似:生成器函數和常規函數幾乎是一樣的。它們都是使用def語句進行定義,差別在於,生成器使用yield語句返回一個值,常規函數使用return語句返回一個值。 2.自動實現迭代器協議:對於生成器,python會自動實現迭代器協議,以便應用到迭代背景中。由於生成器自動實現了迭代協 ...
  • 函數 def 關鍵字 定義 定義一個函數 調用函數 函數的返回值 位置函數 總結 ...
  • 一、繼承 1. 概念 繼承是一種創建新類的方式,新建的類可以繼承一個或多個父類(python支持多繼承),父類又可稱為基類或超類,新建的類稱為派生類或子類。 子類會“”遺傳”父類的屬性,從而解決代碼重用問題。 查看繼承 在開發程式的過程中,如果我們定義了一個類A,然後又想新建立另外一個類B,但是類B ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...