小杉坐在教室裏,透過口袋同樣的窗戶看口袋同樣的天空。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'。
3 1 2 1 2 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 }