ZOJ1406 POJ1251 Jungle Roads,Prim算法~

105 篇文章 0 订阅
2 篇文章 0 订阅

这题是很简单的Prim算法应用,不解释。。。


/*******************************************************************************
 # Author : Neo Fung
 # Email : neosfung@gmail.com
 # Last modified: 2011-08-20 18:23
 # Filename: ZOJ1406 POJ1251 Jungle Roads.cpp
 # Description : 
 ******************************************************************************/
// ZOJ1406 POJ1251 Jungle Roads.cpp : Defines the entry point for the console application.
//

// #include "stdafx.h"



#include <fstream>
#include <stdio.h>
#include <iostream>
#include <memory.h>

using namespace std;

#define INF 1<<30

int map[27][27];
int dij[27];

int prim(int start,int n);
int input(int n);

int main(void)
{
	int n;

	while(cin>>n && n)
	{
		input(n);
		printf("%d\n",prim(0,n));
	}
	return 0;
}

int input(int n)
{
	int len,num;
	char a,b;

	for(int i=0;i<n;++i)
	{
		for(int j=0;j<n;++j)
			map[i][j]=INF;
		map[i][i]=INF;
		dij[i]=INF;
	}

	for(int i=0;i<n-1;++i)
	{
		cin>>a>>num;
		a-='A';
		for(int j=0;j<num;++j)
		{
			cin>>b>>len;
			b-='A';
			map[a][b]=map[b][a]=len;
		}
	}
	return 0;
}

int prim(int start,int n)
{
	int visit[27];
	memset(visit,0,sizeof(visit));

	int now=start;
	visit[now]=1;
	dij[now]=0;

	for(int i=0;i<n;++i)
	{
		int mini(INF);
		for(int j=0;j<n;++j)
			if(!visit[j] && map[now][j]<INF && dij[j]>map[now][j])
				dij[j]=map[now][j];

		for(int j=0;j<n;++j)
			if(!visit[j] && dij[j]<mini)
				mini = dij[now=j];
		visit[now]=1;
	}

	int sum(0);
	for(int i=0;i<n;++i)
		sum+=dij[i];

	return sum;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值