ZOJ1406 POJ1251 Jungle Roads, Prim 알고리즘 ~
/*******************************************************************************
# Author : Neo Fung
# Email : [email protected]
# 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
",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;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.