CCF模擬題 最優灌溉

2022-03-05 19:16:33 字數 1657 閱讀 8479

最優灌溉

時間限制:

1.0s

記憶體限制:

256.0mb

問題描述

雷雷承包了很多片麥田,為了灌溉這些麥田,雷雷在第乙個麥田挖了一口很深的水井,所有的麥田都從這口井來引水灌溉。

為了灌溉,雷雷需要建立一些水渠,以連線水井和麥田,雷雷也可以利用部分麥田作為「中轉站」,利用水渠連線不同的麥田,這樣只要一片麥田能被灌溉,則與其連線的麥田也能被灌溉。

現在雷雷知道哪些麥田之間可以建設水渠和建設每個水渠所需要的費用(注意不是所有麥田之間都可以建立水渠)。請問灌溉所有麥田最少需要多少費用來修建水渠。

輸入格式

輸入的第一行包含兩個正整數n, m,分別表示麥田的片數和雷雷可以建立的水渠的數量。麥田使用1, 2, 3, ……依次標號。

接下來m行,每行包含三個整數ai, bi, ci,表示第ai片麥田與第bi片麥田之間可以建立一條水渠,所需要的費用為ci。

輸出格式

輸出一行,包含乙個整數,表示灌溉所有麥田所需要的最小費用。

樣例輸入

4 41 2 1

2 3 4

2 4 2

3 4 3

樣例輸出

6樣例說明

建立以下三條水渠:麥田1與麥田2、麥田2與麥田4、麥田4與麥田3。

評測用例規模與約定

前20%的評測用例滿足:n≤5。

前40%的評測用例滿足:n≤20。

前60%的評測用例滿足:n≤100。

所有評測用例都滿足:1≤n≤1000,1≤m≤100,000,1≤ci≤10,000。

解題:最小生成樹

1 #include 2

#define ll long long

3#define inf 0x3f3f3f3f3f3f3f

4#define pii pair5

using

namespace

std;

6const

int maxn = 2000;7

struct

arc14 }e[500000

];15

inttot,n,m,head[maxn];

16ll d[maxn];

17bool

done[maxn];

18void add(int u,int v,int

cost)

24 priority_queue< pii,vector< pii >,greater< pii > >q;

25ll prim()

31 q.push(make_pair(d[1] = 0,1

));32 ll ans = 0;33

while(!q.empty())44}

45}46return

ans;47}

48int

main()

56 printf("

%i64d\n

",prim());57}

58return0;

59 }

view code

CCF 最優灌溉

問題描述 試題編號 201412 4 試題名稱 最優灌溉 時間限制 1.0s 記憶體限制 256.0mb 問題描述 問題描述 雷雷承包了很多片麥田,為了灌溉這些麥田,雷雷在第乙個麥田挖了一口很深的水井,所有的麥田都從這口井來引水灌溉。為了灌溉,雷雷需要建立一些水渠,以連線水井和麥田,雷雷也可以利用部...

ccf 最優灌溉

問題描述 雷雷承包了很多片麥田,為了灌溉這些麥田,雷雷在第乙個麥田挖了一口很深的水井,所有的麥田都從這口井來引水灌溉。為了灌溉,雷雷需要建立一些水渠,以連線水井和麥田,雷雷也可以利用部分麥田作為 中轉站 利用水渠連線不同的麥田,這樣只要一片麥田能被灌溉,則與其連線的麥田也能被灌溉。現在雷雷知道哪些麥...

CCF 最優灌溉

問題描述 雷雷承包了很多片麥田,為了灌溉這些麥田,雷雷在第乙個麥田挖了一口很深的水井,所有的麥田都從這口井來引水灌溉。為了灌溉,雷雷需要建立一些水渠,以連線水井和麥田,雷雷也可以利用部分麥田作為 中轉站 利用水渠連線不同的麥田,這樣只要一片麥田能被灌溉,則與其連線的麥田也能被灌溉。現在雷雷知道哪些麥...