90分WA求助
  • 板块P1119 灾后重建
  • 楼主Gary88
  • 当前回复0
  • 已保存回复0
  • 发布时间2020/8/23 19:07
  • 上次更新2023/11/6 19:34:47
查看原帖
90分WA求助
104963
Gary88楼主2020/8/23 19:07
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int m,n,q,b[20005],a[205][205],t,k,d[205][205];
int main()
{
	scanf("%d%d",&n,&m);
	memset(b,0x3f,sizeof(b));
	for(int i=0;i<n;i++)
	{
		scanf("%d",&b[i]);
	}
	for(int i=1;i<=m;i++)
	{
		int x,y,z;
		scanf("%d%d%d",&x,&y,&z);
		a[x][y]=a[y][x]=z;
	}
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<n;j++)
		{
			if(i==j)
			{
				d[i][j]=0;
			}
			else if(a[i][j])
			{
				d[i][j]=a[i][j];
			}
			else
			{
				d[i][j]=1e9+10;
			}
		}
	}
	scanf("%d",&q);
	while(q--)
	{
		int x,y,z;
		scanf("%d%d%d",&x,&y,&z);
			while(b[k]<=z)
			{
				for(int i=0;i<n;i++)
				{
					for(int j=0;j<n;j++)
					{
						d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
					}
				}
				k++;
			}
		if(x>=k||y>=k||d[x][y]==1e9+10)
		{
			printf("-1\n");
		}
		else
		{
			printf("%d\n",d[x][y]);
		}
	}
	return 0;
}
2020/8/23 19:07
加载中...