80分,WA了5和10,求调
查看原帖
80分,WA了5和10,求调
323130
YEMIYZ楼主2021/10/21 21:43

具体思路和题解第一篇差不多

第五组read 5 expected 6

第十组read 0 expected 1

奇怪的是set里不应该插入0,怎么会输出0 ?

f[205][205]最短路 p[205][205]两点间的重要城市

#include<bits/stdc++.h>
using namespace std;
int p[205][205];
int f[205][205];
set<int>s;
int main()
{
	int n,m;
	cin>>n>>m;
	memset(f,0x3f,sizeof(f));
	for(int i=1;i<=m;i++)
	{
		int x,y,z;
		cin>>x>>y>>z;
		f[x][y]=z;
		f[y][x]=z;
	}
	for(int k=1;k<=n;k++)
		for(int i=1;i<=n;i++)
			for(int j=1;j<=n;j++)
			{
				if(f[i][j]>f[i][k]+f[k][j])
				{
					f[i][j]=f[i][k]+f[k][j];
					p[i][j]=k;
				}
				else 
					if(f[i][j]==f[i][k]+f[k][j])
						p[i][j]=0;
			}
	for(int i=1;i<=n;i++)
		for(int j=1;j<=n;j++)
			if(p[i][j])
				s.insert(p[i][j]);
	if(s.empty())
	{
		cout<<"No important cities.";
		return 0;
	}
	for(set<int>::iterator it=s.begin();it!=s.end();it++)
		cout<<*it<<" ";
	return 0;
}

2021/10/21 21:43
加载中...