|
Posted on 2011-09-08 13:21 成幸毅 阅读(289) 评论(0) 编辑 收藏 引用
#include <iostream>
#include <cmath>
#include <queue>
using namespace std;
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" struct Edge {
int v,w,next;
}edge[100010];
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
const int INF = 0x3fffffff
int sps,head[101],w[101],dist[101];
bool inq[101],n,m;
int f[100001];
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" void addedge(int u,int v, int w) {
edge[sps].v = v;
edge[sps].w = w;
edge[sps].next = head[u]
head[u] = sps++;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" void spfa() {
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 0; i <= n; i++) {
dist[i] = ((i==0)?0:INF);
}
queue<int> q;
q.push(0);
memset(inq,0,sizeof(inq));
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" while(!q.empty()) {
int u = q.front();q.pop();
inq[u] = false;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int addr = head[u];addr != -1;addr = edge[addr].next) {
int v = edge[addr].v;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" if(dist[v] > dist[u] + edge[addr].w) {
dist[v] = dist[u] + edge[addr].w;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" if(!inq[v]) {
inq[v] = true;
q.push(v);
}
}
}
}
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" int main() {
int cas;
scanf("%d",&cas);
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" while(cas--) {
sps = 0;
memset(head,-1,sizeof(head));
scanf("%d%d",&n,&m);
int a,b,c;
int tot = 0;
int cnt = 0;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 0; i < m; i++) {
scanf("%d%d%d",&a,&b,&c);
addedge(a,b,c);
addedge(b,a,c);
}
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 1; i <= n; i++) {
scanf("%d",&w[i]);
cnt += w[i];
}
spfa();
int flag = 0;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 1; i <= n; i++) {
tot += dist[i];
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" if(dist[i] == INF) { cout<<"impossible"<<endl;flag = 1;break;}
}
if(flag) continue;
for(int i = 0; i < 100001; i++)
f[i] = 0;
cnt = cnt/2 + 1;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 1; i <= n;i++) {
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int j = tot; j >= dist[i]; j--) {
f[j] = max(f[j],f[j-dist[i]] + w[i]);
}
}
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" for(int i = 1; i <= tot; i++) {
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" if(f[i] >= cnt) {
cout<<i<<endl;
break;
}
}
}
// system("pause");
return 0;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
|