记录编号 469789 评测结果 AAAAAAAAAA
题目名称 [NOIP 2012]文化之旅 最终得分 100
用户昵称 GravatarHtBest 是否通过 通过
代码语言 C++ 运行时间 0.005 s
提交时间 2017-11-03 19:31:06 内存使用 2.21 MiB
显示代码纯文本
#include<cstdio>
#include<algorithm>

using namespace std;
const int maxn=105;
const int maxm=100005;

struct edge
{
	int from,to,len,next;
};

int n,k,m,s,t;
int cul[maxn];
bool A[maxn][maxn];

int first[maxm];
edge E[maxm];

void addedge(int f,int t,int l,int p)
{
	E[p].from=f;
	E[p].to=t;
	E[p].len=l;
	E[p].next=first[f];
	first[f]=p;
} 

int ans=1<<30;

bool vis[maxn];
bool culvis[maxn];
bool flg=0;

void dfs(int st,int step)
{
	if(st==t) 
	{
		ans=min(ans,step);
		flg=1;
		return;
	}
	
	int p=first[st];
	bool flag=0;
	while(p!=0)
	{
		int tp=E[p].to;
		if(E[p].len>ans)
		{
			p=E[p].next;
			continue;
		}
		if(vis[tp]==0 && culvis[cul[tp]]==0)
		{
			for(int i=1;i<=k;i++)
			{
				if(A[cul[tp]][i]==1 && culvis[i]==1)
				{
					flag=1;
					break;
				}
			}
			if(flag==1) 
			{
				p=E[p].next;
				flag^=1;
				continue;
			}
			vis[tp]=1;
			culvis[cul[tp]]=1;
			dfs(tp,step+E[p].len);
			vis[tp]=0;
			culvis[cul[tp]]=0;
		}
		p=E[p].next;
	}
	if(flg==0) ans=-1;
}

int main()
{
	freopen("culture.in","r",stdin);
	freopen("culture.out","w",stdout);
	scanf("%d%d%d%d%d",&n,&k,&m,&s,&t);
	for(int i=1;i<=n;i++) scanf("%d",&cul[i]);
	for(int i=1;i<=k;i++)
	{
		A[i][i]=1;
		for(int j=1;j<=k;j++)
		{
			int tp;
			scanf("%d",&tp);
			if(tp==1) A[i][j]=1;
		}
	}
	
	for(int i=1,a,b,c;i<=2*m;i+=2)
	{
		scanf("%d%d%d",&a,&b,&c);
		addedge(a,b,c,i);
		addedge(b,a,c,i+1);
	}
	vis[s]=1;
	culvis[cul[s]]=1;
	dfs(s,0);
	printf("%d",ans);
	
	fclose(stdin); 
	fclose(stdout);
	return 0;
}