洛谷 P1195 口袋的天空

題目背景

小杉坐在教室裏,透過口袋同樣的窗戶看口袋同樣的天空。ios

有不少雲飄在那裏,看起來很漂亮,小杉想摘下那樣美的幾朵雲,作成棉花糖。ide

題目描述

給你雲朵的個數N,再給你M個關係,表示哪些雲朵能夠連在一塊兒。測試

如今小杉要把全部雲朵連成K個棉花糖,一個棉花糖最少要用掉一朵雲,小杉想知道他怎麼連,花費的代價最小。spa

輸入輸出格式

輸入格式:3d

 

每組測試數據的code

第一行有三個數N,M,K(1<=N<=1000,1<=M<=10000,1<=K<=10)blog

接下來M個數每行三個數X,Y,L,表示X雲和Y雲能夠經過L的代價連在一塊兒。(1<=X,Y<=N,0<=L<10000)ip

30%的數據N<=100,M<=1000ci

 

輸出格式:get

 

對每組數據輸出一行,僅有一個整數,表示最小的代價。

若是怎麼連都連不出K個棉花糖,請輸出'No Answer'。

 

輸入輸出樣例

輸入樣例#1:
3 1 2
1 2 1
輸出樣例#1:
1

說明

廈門一中YMS原創

————————————————--我是分割線————————————————————

  1 /*
  2     Problem:
  3     OJ:
  4     User:S.B.S.
  5     Time:
  6     Memory:
  7     Length:
  8 */
  9 #include<iostream>
 10 #include<cstdio>
 11 #include<cstring>
 12 #include<cmath>
 13 #include<algorithm>
 14 #include<queue>
 15 #include<cstdlib>
 16 #include<iomanip>
 17 #include<cassert>
 18 #include<climits>
 19 #include<functional>
 20 #include<bitset>
 21 #include<vector>
 22 #include<list>
 23 #include<utility>
 24 #include<map>
 25 #define maxn 1001
 26 #define F(i,j,k) for(int i=j;i<=k;i++)
 27 #define rep(i,j,k) for(int i=j;i<k;i++)
 28 #define M(a,b) memset(a,b,sizeof(a))
 29 #define FF(i,j,k) for(int i=j;i>=k;i--)
 30 #define inf 0x3f3f3f3f
 31 #define maxm 10001
 32 #define mod 998244353
 33 //#define LOCAL
 34 using namespace std;
 35 inline int read(){
 36     int x=0,f=1;char ch=getchar();
 37     while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
 38     while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
 39     return x*f;
 40 }
 41 inline void out(int n){
 42     if(n<0){putchar('-');n=0-n;}
 43     if(n>=10) out(n/10);
 44     putchar((n%10)+'0');
 45     return;
 46 }
 47 int n,m,k;
 48 int tot,ans,cnt;
 49 struct EDGE
 50 {
 51     int from;
 52     int to;
 53     int value;
 54 }e[maxm];
 55 int fa[maxn],rank[maxn];
 56 inline void addedge(int u,int v,int w)
 57 {
 58     tot++;
 59     e[tot].from=u;
 60     e[tot].to=v;
 61     e[tot].value=w;
 62     return;
 63 }
 64 bool cmp(EDGE a,EDGE b) {return a.value<b.value;}
 65 inline void init() {F(i,1,n) fa[i]=i,rank[i]=0;}
 66 inline int find(int u) {return fa[u]==u ? u : fa[u]=find(fa[u]);}
 67 inline void Union(int a,int b)
 68 {
 69     int x=find(a),y=find(b);
 70     if(x==y) return;
 71     if(rank[x]>rank[y]) fa[x]=y;
 72     else{
 73         fa[y]=x;
 74         if(rank[x]==rank[y]) rank[y]++;
 75     }
 76 }
 77 int d[maxm],cur;
 78 inline void kruscal()
 79 {
 80     init();sort(e+1,e+m+1,cmp);
 81     F(i,1,m){
 82         int a=find(e[i].from),b=find(e[i].to);
 83         if(a==b) continue;
 84         else{
 85             d[++cur]=i;cnt++;ans+=e[i].value;
 86             Union(e[i].from,e[i].to);
 87         }
 88         if(cnt==(n-k)) break;
 89     }
 90 }
 91 int main()
 92 {
 93     std::ios::sync_with_stdio(false);//cout<<setiosflags(ios::fixed)<<setprecision(1)<<y;
 94     #ifdef LOCAL
 95     freopen("data.in","r",stdin);
 96     freopen("data.out","w",stdout);
 97     #endif
 98     cin>>n>>m>>k;
 99     F(i,1,m){
100         int a,b,c;cin>>a>>b>>c;
101         addedge(a,b,c);
102     }
103     kruscal();
104     cout<<ans<<endl;
105     return 0;
106 }
View Code
相關文章
相關標籤/搜索