整套题都没什么难度、

POJ 1251 Jungle Roads

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
struct Edge
{
int u,v,w;
friend bool operator < (const Edge &a,const Edge &b)
{
return a.w < b.w;
}
}edge[];
int fa[MAXN];
int M;
int Find(int x){return x == fa[x] ? x : fa[x] = Find(fa[x]);} void kruskal(int N)
{
for (int i = ; i < MAXN ; i++) fa[i] = i;
sort(edge,edge + M);
int cnt = ;
int ret = ;
for (int i = ; i < M ; i++)
{
int fu = Find(edge[i].u);
int fv = Find(edge[i].v);
if (fu != fv)
{
fa[fv] = fu;
cnt++;
ret += edge[i].w;
}
if (cnt >= N - ) break;
}
printf("%d\n",ret);
} int main()
{
int N;
while (scanf("%d",&N) != EOF)
{
if (N == ) break;
M = ;
for (int i = ; i < N - ; i++)
{
char op[];
int tot;
scanf("%s%d",op,&tot);
int id = op[] - 'A';
while (tot--)
{
int val;
char tag[];
scanf("%s%d",tag,&val);
edge[M].u = id;
edge[M].v = tag[] - 'A';
edge[M].w = val;
M++;
}
}
kruskal(N);
}
return ;
}

POJ 1287 Networking

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
int dis[MAXN][MAXN];
int lowcost[MAXN];
bool vis[MAXN]; void prim(int N)
{
memset(vis,false,sizeof(vis));
for (int i = ; i < MAXN ; i++) lowcost[i] = dis[][i];
vis[] = true;
lowcost[] = ;
int ret = ;
for (int i = ; i <= N ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
pos = j;
mincost = lowcost[j];
}
}
if (pos == -) break;
ret += mincost;
vis[pos] = true;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
printf("%d\n",ret);
} int main()
{
int N,M;
while (scanf("%d",&N) != EOF)
{
if (N == ) break;
scanf("%d",&M);
memset(dis,0x3f,sizeof(dis));
for (int i = ; i < M ; i++)
{
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
dis[u][v] = min(dis[u][v],w);
dis[v][u] = min(dis[v][u],w);
}
prim(N);
}
return ;
}

POJ 2031 Building a Space Station

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const double eps = 1e-;
struct circle
{
double x,y,z;
double r;
}src[MAXN];
struct Edge
{
int u,v;
double w;
friend bool operator < (const Edge &a,const Edge &b)
{
return a.w < b.w;
}
}edge[MAXN * MAXN];
int tot,N;
int fa[MAXN];
int Find(int x){return x == fa[x] ? x : fa[x] = Find(fa[x]);} void kruskal(int N)
{
double ret = ;
int cnt = ;
for (int i = ; i < tot ; i++)
{
int fu = Find(edge[i].u);
int fv = Find(edge[i].v);
if (fu != fv)
{
ret += edge[i].w;
fa[fv] = fu;
cnt++;
}
if (cnt >= N - ) break;
}
printf("%.3lf\n",ret);
} int main()
{
while (scanf("%d",&N) != EOF)
{
if (N == ) break;
for (int i = ; i <= N ; i++)
scanf("%lf%lf%lf%lf",&src[i].x,&src[i].y,&src[i].z,&src[i].r);
tot = ;
for (int i = ; i <= N ; i++) fa[i] = i;
for (int i = ; i <= N ; i++)
{
for (int j = i + ; j <= N ; j++)
{
double dis = sqrt((src[i].x - src[j].x) * (src[i].x - src[j].x) + (src[i].y - src[j].y) * (src[i].y - src[j].y) + (src[i].z - src[j].z) * (src[i].z - src[j].z));
if (dis > src[i].r + src[j].r)
{
edge[tot].u = i;
edge[tot].v = j;
edge[tot].w = dis - src[i].r - src[j].r;
tot++;
}
else
{
int fi = Find(i),fj = Find(j);
if (fi != fj)
{
fa[fj] = fi;
}
}
}
}
sort(edge,edge + tot);
kruskal(N);
}
return ;
}

POJ 2421 Constructing Roads

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
int dis[MAXN][MAXN];
int lowcost[MAXN];
bool vis[MAXN]; void prim(int N)
{
memset(vis,false,sizeof(vis));
for (int i = ; i <= N ; i++) lowcost[i] = dis[][i];
lowcost[] = ;
vis[] = true;
int ret = ;
for (int i = ; i <= N ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) break;
ret += mincost;
vis[pos] = true;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
printf("%d\n",ret);
} int main()
{
int N,M;
while (scanf("%d",&N) != EOF)
{
for (int i = ; i <= N ; i++)
for (int j = ; j <= N ; j++) scanf("%d",&dis[i][j]);
int Q;
scanf("%d",&Q);
while (Q--)
{
int u,v;
scanf("%d%d",&u,&v);
int tmp = dis[u][v];
dis[u][v] = dis[v][u] = ;
}
prim(N);
}
return ;
}

ZOJ 1586 QS Network

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int MAXM = MAXN * MAXN;
struct Edge
{
int u,v,w;
friend bool operator < (const Edge &a,const Edge &b)
{
return a.w < b.w;
}
}edge[MAXM];
int fa[MAXN],price[MAXN];
int tot;
int Find(int x) {return x == fa[x] ? x : fa[x] = Find(fa[x]);} void kruskal(int N)
{
for (int i = ; i <= N ; i++) fa[i] = i;
sort(edge,edge + tot);
int cnt = ,ret = ;
for (int i = ; i < tot ; i++)
{
int fu = Find(edge[i].u);
int fv = Find(edge[i].v);
if (fu != fv)
{
fa[fv] = fu;
cnt++;
ret += edge[i].w;
}
if (cnt >= N - ) break;
}
printf("%d\n",ret);
} int main()
{
int T;
scanf("%d",&T);
while (T--)
{
int N;
scanf("%d",&N);
for (int i = ; i <= N ; i++) scanf("%d",&price[i]);
tot = ;
for (int i = ; i <= N ; i++)
{
for (int j = ; j <= N ; j++)
{
int x;
scanf("%d",&x);
if (i < j)
{
edge[tot].u = i;
edge[tot].v = j;
edge[tot++].w = x + price[i] + price[j];
}
}
}
kruskal(N);
}
return ;
}

POJ 1789 Truck History

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
int dis[MAXN][MAXN];
char word[MAXN][];
int lowcost[MAXN];
bool vis[MAXN]; void prim(int N)
{
memset(vis,false,sizeof(vis));
for (int i = ; i <= N ; i++) lowcost[i] = dis[][i];
vis[] = true;
lowcost[] = ;
int ret = ;
for (int i = ; i <= N ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) break;
vis[pos] = true;
ret += mincost ;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
printf("The highest possible quality is 1/%d.\n",ret);
} int cal(int x,int y)
{
int cnt = ;
for (int i = ; i < ; i++)
if (word[x][i] != word[y][i]) cnt++;
return cnt;
} int main()
{
int N;
while (scanf("%d",&N) != EOF)
{
if (N == ) break;
for (int i = ; i <= N ; i++) scanf("%s",word[i]);
for (int i = ; i <= N ; i++)
{
for (int j = i + ; j <= N ; j++)
{
int dist = cal(i,j);
dis[i][j] = dist;
dis[j][i] = dist;
}
}
prim(N);
}
return ;
}

POJ 2349 Arctic Network

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int MAXM = MAXN * MAXN;
int fa[MAXN];
int Find(int x) {return x == fa[x] ? x : fa[x] = Find(fa[x]);}
struct node
{
double x,y;
}src[MAXN];
struct Edge
{
int u,v;
double w;
friend bool operator <(const Edge &a,const Edge & b)
{
return a.w < b.w;
}
}edge[MAXM];
int S,P;
vector<double>ans;
int cas; void build()
{
cas = ;
for (int i = ; i <= P ; i++) scanf("%lf%lf",&src[i].x,&src[i].y);
for (int i = ; i <= P ; i++)
{
for (int j = i + ; j <= P ; j++)
{
double dis = sqrt((src[j].x - src[i].x) * (src[j].x - src[i].x)
+ (src[j].y - src[i].y) * (src[j].y - src[i].y));
edge[cas].u = i;
edge[cas].v = j;
edge[cas].w = dis;
cas++;
edge[cas].v = i;
edge[cas].u = j;
edge[cas].w = dis;
cas++;
}
}
}
int cmp(const double &a,const double &b)
{
return a > b;
}
void kruskal()
{
for (int i = ; i <= P ; i++) fa[i] = i;
double ret = ;
int cnt = ;
ans.clear();
sort(edge,edge + cas);
for (int i = ; i < cas ; i++)
{
int fu = Find(edge[i].u);
int fv = Find(edge[i].v);
if (fu != fv)
{
cnt++;
ret += edge[i].w;
ans.push_back(edge[i].w);
fa[fu] = fv;
}
if (cnt >= P - ) break;
}
//printf("%lf\n",ret);
sort(ans.begin(),ans.end(),cmp);
if (S >= P) printf("0.00\n");
else
{
S--;
printf("%.2f\n",ans[S]);
}
//printf("%.2lf\n",max(ret,0.0));
} int main()
{
int T;
scanf("%d",&T);
while (T--)
{
scanf("%d%d",&S,&P);
build();
kruskal();
}
return ;
}

POJ 1751 Highways

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
int fa[MAXN];
int Find(int x) {return x == fa[x] ? x : fa[x] = Find(fa[x]);}
int x[MAXN],y[MAXN];
struct Edge
{
int u,v,w;
friend bool operator < (const Edge &a,const Edge &b)
{
return a.w < b.w;
}
}edge[MAXN * MAXN / ];
int N,tot; void kruskal(int N)
{
sort(edge,edge + tot);
int cnt = ;
for (int i = ; i < tot ; i++)
{
int fu = Find(edge[i].u);
int fv = Find(edge[i].v);
if (fu != fv)
{
printf("%d %d\n",edge[i].u,edge[i].v);
fa[fv] = fu;
cnt++;
}
if (cnt >= N - ) break;
}
} int main()
{
scanf("%d",&N);
{
tot = ;
for (int i = ; i <= N ; i++)scanf("%d%d",&x[i],&y[i]);
for (int i = ; i <= N ; i++)
{
for (int j = i + ; j <= N ; j++)
{
int tmp = (x[i] - x[j]) * (x[i] - x[j]) + (y[i] - y[j]) * (y[i] - y[j]);
edge[tot].u = i;
edge[tot].v = j;
edge[tot].w = tmp;
tot++;
}
}
for (int i = ; i <= N ; i++) fa[i] = i;
int M;
scanf("%d",&M);
while (M--)
{
int u,v;
scanf("%d%d",&u,&v);
int fu = Find(u);
int fv = Find(v);
if (fu != fv)
{
fa[fv] = fu;
}
}
kruskal(N);
}
return ;
}

POJ 1258 Agri-Net

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
LL lowcost[MAXN];
LL dis[MAXN][MAXN];
bool vis[MAXN]; void prim(int N)
{
memset(vis,false,sizeof(vis));
for (int i = ; i <= N ; i++) lowcost[i] = dis[][i];
lowcost[] = ;
vis[] = true;
LL ret = ;
for (int i = ; i <= N ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) break;
ret += mincost;
vis[pos] = true;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
printf("%lld\n",ret);
} int main()
{
int N;
while (scanf("%d",&N) != EOF)
{
for (int i = ; i <= N ; i++)
for (int j = ; j <= N ; j++) scanf("%lld",&dis[i][j]);
prim(N);
}
return ;
}

POJ 3026 Borg Maze

这道题我就也无语了。看了Discuss就知道他究竟就多多多多多坑,呵呵

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
const int MAXD = ;
const int dx[] = {,,,-};
const int dy[] = {,-,,};
char G[MAXN][MAXN];
queue<pair<int,int> >q;
int N,M;
int dis[MAXN][MAXN];
int dist[MAXD][MAXD];
bool vis[MAXD][MAXD];
int id[MAXN][MAXN],tot; void bfs(int x,int y)
{
memset(vis,false,sizeof(vis));
int idx = id[x][y];
while (!q.empty()) q.pop();
dist[x][y] = ;
dis[idx][idx] = ;
q.push(make_pair(x,y));
vis[x][y] = true;
while (!q.empty())
{
pair<int,int>u = q.front(); q.pop();
int fidx = id[u.first][u.second];
for (int d = ; d < ; d++)
{
int nx = u.first + dx[d];
int ny = u.second + dy[d];
int nidx = id[nx][ny];
if (!vis[nx][ny] && nx >= && nx <= N && ny >= && ny <= M && G[nx][ny] == ' ')
{
vis[nx][ny] = true;
dist[nx][ny] = dist[u.first][u.second] + ;
q.push(make_pair(nx,ny));
}
else if (!vis[nx][ny] && nx >= && nx <= N && ny >= && ny <= M && isupper(G[nx][ny]))
{
vis[nx][ny] = true;
dist[nx][ny] = dist[u.first][u.second] + ;
q.push(make_pair(nx,ny));
int nidx = id[nx][ny];
dis[idx][nidx] = dist[nx][ny];
}
}
}
} int lowcost[MAXN];
bool used[MAXN]; void prim(int N)
{
memset(used,false,sizeof(used));
for (int i = ; i <= N ; i++) lowcost[i] = dis[][i];
lowcost[] = ;
used[] = true;
int ret = ;
for (int i = ; i <= N ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= N ; j++)
{
if (!used[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) break;
ret += mincost;
used[pos] = true;
for (int j = ; j <= N ; j++)
{
if (!used[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
printf("%d\n",ret);
} int main()
{
int T;
char tmp[];
scanf("%d",&T);
while (T--)
{
scanf("%d%d",&M,&N);
gets(tmp);
memset(id,-,sizeof(id));
int cas = ;
for (int i = ; i <= N ; i++)gets(G[i] + );
for (int i = ; i <= N ; i++)
{
for (int j = ; j <= M ; j++)
if (G[i][j] == 'A' || G[i][j] == 'S')
id[i][j] = ++cas;
}
for (int i = ; i <= N ; i++)\
{
for (int j = ; j <= M ; j++)
if (isupper(G[i][j]))
bfs(i,j);
}
prim(cas);
}
return ;
}

POJ 1679 The Unique MST

求次小生成树

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
bool vis[MAXN];
int cost[MAXN][MAXN];
int lowcost[MAXN];
int pre[MAXN],MAX[MAXN][MAXN];
bool used[MAXN][MAXN]; int prim(int cost[][MAXN],int n)
{
int ret = ;
memset(vis,false,sizeof(vis));
memset(MAX,,sizeof(MAX));
memset(used,false,sizeof(used));
vis[] = true;
pre[] = -;
for (int i = ; i <= n ; i++)
{
lowcost[i] = cost[][i];
pre[i] = ;
}
lowcost[] = ;
pre[] = -;
for (int i = ; i <= n ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= n ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) return -;
ret += mincost;
vis[pos] = true;
used[pos][pre[pos]] = used[pre[pos]][pos] = true;
for (int j = ; j <= n ; j++)
{
if (vis[j]) MAX[j][pos] = MAX[pos][j] = max(MAX[j][pre[pos]],lowcost[pos]);
if (!vis[j] && lowcost[j] > cost[pos][j])
{
lowcost[j] = cost[pos][j];
pre[j] = pos;
}
}
}
return ret;
} int calcusmst(int cost[][MAXN],int n,int ret)
{
int MIN = INF;
for (int i = ; i <= n ; i++)
{
for (int j = i + ; j <= n ; j++)
{
if (cost[i][j] < INF && !used[i][j])
MIN = min(MIN,ret + cost[i][j] - MAX[i][j]);
}
}
if (MIN == INF) return -;
return MIN;
} int main()
{
int T,N,M;
scanf("%d",&T);
while (T--)
{
scanf("%d%d",&N,&M);
for (int i = ; i <= N ; i++)
for (int j = ; j <= N ; j++) cost[i][j] = i == j ? : INF;
while (M--)
{
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
cost[u][v] = cost[v][u] = w;
}
int ret = prim(cost,N);
if (ret == -)
{
printf("Not Unique!\n");
continue;
}
if (ret == calcusmst(cost,N,ret)) printf("Not Unique!\n");
else printf("%d\n",ret);
}
return ;
}

HDU 1233 还是畅通工程

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const int INF = 0x3f3f3f3f;
int dis[MAXN][MAXN];
int lowcost[MAXN];
bool vis[MAXN]; void prim(int N)
{
memset(vis,false,sizeof(vis));
for (int i = ; i <= N ; i++) lowcost[i] = dis[][i];
vis[] = true;
lowcost[] = ;
int ret = ;
for (int i = ; i <= N ; i++)
{
int mincost = INF;
int pos = -;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) break;
ret += mincost;
vis[pos] = true;
for (int j = ; j <= N ; j++)
{
if (!vis[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
printf("%d\n",ret);
} int main()
{
int N;
while (scanf("%d",&N) != EOF)
{
if (N == ) break;
for (int i = ; i <= N ; i++)
for (int j = ; j <= N ; j++) dis[i][j] = i == j ? : INF;
int tmp = N * (N - ) / ;
for (int i = ; i < tmp ; i++)
{
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
dis[u][v] = dis[v][u] = w;
}
prim(N);
}
return ;
}

HDU 1301 Jungle Roads

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
struct Edge
{
int u,v,w;
friend bool operator < (const Edge &a,const Edge &b)
{
return a.w < b.w;
}
}edge[];
int fa[MAXN];
int M;
int Find(int x){return x == fa[x] ? x : fa[x] = Find(fa[x]);} void kruskal(int N)
{
for (int i = ; i < MAXN ; i++) fa[i] = i;
sort(edge,edge + M);
int cnt = ;
int ret = ;
for (int i = ; i < M ; i++)
{
int fu = Find(edge[i].u);
int fv = Find(edge[i].v);
if (fu != fv)
{
fa[fv] = fu;
cnt++;
ret += edge[i].w;
}
if (cnt >= N - ) break;
}
printf("%d\n",ret);
} int main()
{
int N;
while (scanf("%d",&N) != EOF)
{
if (N == ) break;
M = ;
for (int i = ; i < N - ; i++)
{
char op[];
int tot;
scanf("%s%d",op,&tot);
int id = op[] - 'A';
while (tot--)
{
int val;
char tag[];
scanf("%s%d",tag,&val);
edge[M].u = id;
edge[M].v = tag[] - 'A';
edge[M].w = val;
M++;
}
}
kruskal(N);
}
return ;
}

HDU 1875 畅通工程再续

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
const int MAXN = ;
const double INF = 1e14;
double dis[MAXN][MAXN];
double lowcost[MAXN];
bool vis[MAXN];
double x[MAXN],y[MAXN]; double prim(int n)
{
memset(vis,false,sizeof(vis));
for (int i = ; i <= n ; i++) lowcost[i] = dis[][i];
vis[] = true;
lowcost[] = ;
double ret = ;
for (int i = ; i <= n ; i++)
{
double mincost = INF;
int pos = -;
for (int j = ; j <= n ; j++)
{
if (!vis[j] && lowcost[j] < mincost)
{
mincost = lowcost[j];
pos = j;
}
}
if (pos == -) break;
vis[pos] = true;
ret += mincost;
for (int j = ; j <= n ; j++)
{
if (!vis[j] && lowcost[j] > dis[pos][j])
lowcost[j] = dis[pos][j];
}
}
return ret;
} int main()
{
int T;
scanf("%d",&T);
while (T--)
{
int N;
scanf("%d",&N);
for (int i = ; i <= N ; i++)
{
scanf("%lf%lf",&x[i],&y[i]);
}
for (int i = ; i <= N ; i++)
for (int j = ; j <= N ; j++) dis[i][j] = i == j ? : INF;
for (int i = ; i <= N ; i++)
{
for (int j = i + ; j <= N ; j++)
{
double dist = sqrt((x[i] - x[j]) * (x[i] - x[j]) + (y[i] - y[j]) * (y[i] - y[j]));
// printf("%lf\n",dist);
if (dist >= 10.0 && dist < )
{
dis[i][j] = dis[j][i] = dist;
// printf("%lf\n",dist);
}
}
}
// for (int i = 1 ; i <= N ; i++)
// for (int j = 1 ; j <= N ; j++) printf("%lf%c",dis[i][j],j == N ? '\n' : ' ');
double ret = prim(N);
if (ret >= INF || ret == 0.0) puts("oh!");
else
{
ret *= 100.0;
printf("%.1lf\n",ret);
}
}
return ;
}

Kuangbin 带你飞 最小生成树题解的更多相关文章

  1. KUANGBIN带你飞

    KUANGBIN带你飞 全专题整理 https://www.cnblogs.com/slzk/articles/7402292.html 专题一 简单搜索 POJ 1321 棋盘问题    //201 ...

  2. Tarjan 联通图 Kuangbin 带你飞 联通图题目及部分联通图题目

    Tarjan算法就不说了 想学看这 https://www.byvoid.com/blog/scc-tarjan/ https://www.byvoid.com/blog/biconnect/ 下面是 ...

  3. 「kuangbin带你飞」专题二十 斜率DP

    layout: post title: 「kuangbin带你飞」专题二十 斜率DP author: "luowentaoaa" catalog: true tags: mathj ...

  4. 「kuangbin带你飞」专题二十二 区间DP

    layout: post title: 「kuangbin带你飞」专题二十二 区间DP author: "luowentaoaa" catalog: true tags: - ku ...

  5. 「kuangbin带你飞」专题十九 矩阵

    layout: post title: 「kuangbin带你飞」专题十九 矩阵 author: "luowentaoaa" catalog: true tags: mathjax ...

  6. 「kuangbin带你飞」专题十八 后缀数组

    layout: post title: 「kuangbin带你飞」专题十八 后缀数组 author: "luowentaoaa" catalog: true tags: - kua ...

  7. 「kuangbin带你飞」专题十七 AC自动机

    layout: post title: 「kuangbin带你飞」专题十七 AC自动机 author: "luowentaoaa" catalog: true tags: - ku ...

  8. [kuangbin带你飞]专题1-23题目清单总结

    [kuangbin带你飞]专题1-23 专题一 简单搜索 POJ 1321 棋盘问题POJ 2251 Dungeon MasterPOJ 3278 Catch That CowPOJ 3279 Fli ...

  9. 【算法系列学习三】[kuangbin带你飞]专题二 搜索进阶 之 A-Eight 反向bfs打表和康拓展开

    [kuangbin带你飞]专题二 搜索进阶 之 A-Eight 这是一道经典的八数码问题.首先,简单介绍一下八数码问题: 八数码问题也称为九宫问题.在3×3的棋盘,摆有八个棋子,每个棋子上标有1至8的 ...

随机推荐

  1. 生产者与消费者-N:1-基于list

    多个生产者/一个消费者: /** * 生产者 */ public class P { private MyStack stack; public P(MyStack stack) { this.sta ...

  2. CSP201412-1:门禁系统

    引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的“计算机职业资格认证”考试,针对计算机软件开发. ...

  3. 梳理 Opengl ES 3.0 (一)宏观着眼

    Opengl ES 可以理解为是在嵌入式设备上工作的一层用于处理图形显示的软件,是Opengl 的缩水版本. 下图是它的工作流程示意图: 注意图中手机左边的EGL Layer Opengl ES是跨平 ...

  4. 详说大数据计算的可类化Classable

    可类化(Classable)是Laxcus大数据管理系统提供的一项基础功能,它能够将类转化为一串字节数组,或者逆向将字节数组转化为一个类.这项功能与JAVA提供的序列化(Serializable)非常 ...

  5. 关于Scala文件操作中出现的问题

    在各种项目中,我们常常需要用到文件操作,笔者在近期的项目中遇到了一个与文件操作相关的问题. 在代码实现的过程中,笔者首先定义了一个文件路径:def PATH = "/a/b/c.txt&qu ...

  6. LoadRunner系统架构简介与运行原理

    1.LoadRunner系统架构简介 LoadRunner是通过创建虚拟用户来代替真实实际用户来操作客户端软件比如Internet Explorer,来向IIS.Apache等Web服务器发送HTTP ...

  7. java线程(1)——三种创建线程的方式

    前言 线程,英文Thread.在java中,创建线程的方式有三种: 1.Thread 2.Runnable 3.Callable 在详细介绍下这几种方式之前,我们先来看下Thread类和Runnabl ...

  8. 关于Assert

    如果没有连1394线debug,assert不影响程序的执行,只会在dbgview里面答应"Assertion xxxx"这样的调试信息. 当连着1394线的时候,OS会被hang ...

  9. mysql 数据包太小会引发错误信息

    Error querying database.  Cause: com.mysql.cj.jdbc.exceptions.PacketTooBigException: Packet for quer ...

  10. JSP表单提交出现中文乱码的解决方法

    1)post方式 在servlet的doGet( )  doPost( )  中增加以下代码: response.setContentType("text/html;charset=utf- ...