poj 2485 <prim《模板》求最小生成树>
2016-08-02 09:05
387 查看
题目链接点击打开链接
代码:
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int map[600][600];
int dis[600];
bool fafe[600];int n;
int prim()
{
memset(fafe,true,sizeof(fafe));
for (int i=1;i<=n;i++)
dis[i]=map[1][i];
fafe[1]=false;
int ans=0;
for (int i=1;i<n;i++)
{
int mi=666666,ii=0;
for (int i=1;i<=n;i++)
if (fafe[i]&&dis[i]<mi)
{
mi=dis[i];ii=i;
}
ans=max(mi,ans);
fafe[ii]=false;
for (int i=1;i<=n;i++)
if (fafe[i]&&dis[i]>map[ii][i])
dis[i]=map[ii][i];
}
printf("%d\n",ans);
}
int main()
{
int t;scanf("%d",&t);
while (t--)
{
scanf("%d",&n);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
scanf("%d",&map[i][j]);
prim();
}
return 0;
}
代码:
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int map[600][600];
int dis[600];
bool fafe[600];int n;
int prim()
{
memset(fafe,true,sizeof(fafe));
for (int i=1;i<=n;i++)
dis[i]=map[1][i];
fafe[1]=false;
int ans=0;
for (int i=1;i<n;i++)
{
int mi=666666,ii=0;
for (int i=1;i<=n;i++)
if (fafe[i]&&dis[i]<mi)
{
mi=dis[i];ii=i;
}
ans=max(mi,ans);
fafe[ii]=false;
for (int i=1;i<=n;i++)
if (fafe[i]&&dis[i]>map[ii][i])
dis[i]=map[ii][i];
}
printf("%d\n",ans);
}
int main()
{
int t;scanf("%d",&t);
while (t--)
{
scanf("%d",&n);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
scanf("%d",&map[i][j]);
prim();
}
return 0;
}
相关文章推荐
- POJ 2485:Highways:典型prim最小生成树(2)
- POJ 2485 Highways 最小生成树 Kruskal && Prim
- <模板>poj2031 Building a Space Station(最小生成树)
- poj 2485 Highways(最小生成树,prim)
- POJ 1258:Agri-Net Prim最小生成树模板题
- POJ 2485:Highways(最小生成树&&prim)
- poj 2485 Highways(最小生成树 Prim)
- prim最小生成树算法题poj2485
- poj 2485 Highways -----最小生成树。prim
- POJ 2485 Highways(prim 最小生成树)
- POJ 2485:Highways(最小生成树&&prim)
- poj 2485(prim最小生成树)
- POJ 1258:Agri-Net Prim最小生成树模板题
- poj 2485 Highways prim最小生成树 基础 球最小生成树中得最大边
- POJ 2485 Highways【最小生成树最大权——简单模板】
- 初级->图算法->最小生成树 poj 2485 Highways
- POJ 2485 Highways【最小生成树最大权——简单模板】
- POJ 2485 Highways(最小生成树-Prim)
- POJ 2485 Highways (prim最小生成树)
- POJ 2485 Highways (prim最小生成树)