Silver Cow Party POJ - 3268(迪杰斯特拉)

给出n,m,代表牛数和边数,接着是m条**有向**边,代表从牛a到牛b需要花费c时间,现在所有牛要到牛x那里去参加聚会,并且所有牛参加聚会后还要回来,给你牛x,除了牛x之外的牛,他们都有一个参加聚会并且回来的最短时间,从这些最短时间里找出一个最大值输出 N<=1000,M<=100,000

Input

Line 1: Three space-separated integers, respectively: NM, and X 
Lines 2.. M+1: Line i+1 describes road i with three space-separated integers: Ai,Bi, and Ti. The described road runs from farm Ai to farm Bi, requiring Ti time units to traverse.

Output

Line 1: One integer: the maximum of time any one cow must walk.

Sample Input

4 8 2
1 2 4
1 3 2
1 4 7
2 1 1
2 3 5
3 1 2
3 4 4
4 2 3

Sample Output

10

Hint

Cow 4 proceeds directly to the party (3 units) and returns via farms 1 and 3 (7 units), for a total of 10 time units.

#include<iostream>
#include<algorithm>
#include<string.h>
#include<string>
#include<queue>
#include<cstdio> 
const int maxn=1005;
const int inf=0x3f3f3f3f;;
using namespace std;
typedef long long ll;
typedef pair<int,int> p;


vector<p>ans1[maxn];
int vis[maxn];
int d1[maxn];
int d2[maxn];

int n,m,x;

void di(int start)
{
	memset(vis,0,sizeof(vis));
	memset(d1,inf,sizeof(d1));
	priority_queue<p,vector<p>,greater<p> >q;
	
	d1[start]=0;
	q.push({0,start});
	while(!q.empty())
	{
		p h=q.top();
		q.pop();
		
		int u=h.second;   
		if(vis[u])
			continue;
		vis[u]=1;
		for(int i=0;i<ans1[u].size();i++)
		{
			int v=ans1[u][i].first;
			int c=ans1[u][i].second;
			if(!vis[v]&&d1[v]>c+d1[u])
			{
				d1[v]=c+d1[u];
				q.push({d1[v],v});
			}
			
			
		}
		
	}
}

int main()
{
	scanf("%d%d%d",&n,&m,&x);
	for(int i=1;i<=n;i++)
	{
		ans1[i].clear();
	}
	int a,b,val;
	for(int i=0;i<m;i++)
	{
		scanf("%d%d%d",&a,&b,&val);
		ans1[a].push_back({b,val});
		
	}
	
	
	di(x);
	for(int i=1;i<=n;i++)
		d2[i]=d1[i];

	int  asn=-1;
	for(int i=1;i<=n;i++)
	{
		di(i);
		if(d1[x]!=inf)
		asn=max(asn,d1[x]+d2[i]);
	}
	
	printf("%d\n",asn);
	
	
	return 0;
}

就是去的时候从终点到各个起点跑一个迪杰斯特拉,然后我们想从各个起点跑一个,然后从各个起点跑到终点,每次都用迪杰斯特拉跑一遍,然后找出那个最大的值,然后输出AC。数据量不大的做法。

当然也会有数据量很大的时候:我们就直接在返回的时候,我们将边反转一下,然后再从终点到各个起点跑一个迪杰斯特拉,这样就避免了很多的额外时间。

扫描二维码关注公众号,回复: 8978516 查看本文章

代码:

#include<iostream>
#include<algorithm>
#include<string.h>
#include<string>
#include<queue>
#include<cstdio> 
const int maxn=1005;
const int inf=0x3f3f3f3f;;
using namespace std;
typedef long long ll;
typedef pair<int,int> p;


vector<p>ans1[maxn],ans2[maxn];
int vis[maxn];
int d1[maxn];
int d2[maxn];

int n,m,x;

void di(int start)
{
	memset(vis,0,sizeof(vis));
	memset(d1,inf,sizeof(d1));
	priority_queue<p,vector<p>,greater<p> >q;
	
	d1[start]=0;
	q.push({0,start});
	while(!q.empty())
	{
		p h=q.top();
		q.pop();
		
		int u=h.second;   
		if(vis[u])
			continue;
		vis[u]=1;
		for(int i=0;i<ans1[u].size();i++)
		{
			int v=ans1[u][i].first;
			int c=ans1[u][i].second;
			if(!vis[v]&&d1[v]>c+d1[u])
			{
				d1[v]=c+d1[u];
				q.push({d1[v],v});
			}
			
			
		}
		
	}
}

void di2(int start)
{
	memset(vis,0,sizeof(vis));
	memset(d1,inf,sizeof(d1));
	priority_queue<p,vector<p>,greater<p> >q;
	
	d1[start]=0;
	q.push({0,start});
	while(!q.empty())
	{
		p h=q.top();
		q.pop();
		
		int u=h.second;   
		if(vis[u])
			continue;
		vis[u]=1;
		for(int i=0;i<ans2[u].size();i++)
		{
			int v=ans2[u][i].first;
			int c=ans2[u][i].second;
			if(!vis[v]&&d1[v]>c+d1[u])
			{
				d1[v]=c+d1[u];
				q.push({d1[v],v});
			}
			
			
		}
		
	}
	
	
	
	
	
	
	
}


int main()
{
	scanf("%d%d%d",&n,&m,&x);
	for(int i=1;i<=n;i++)
	{
		ans1[i].clear();
		ans2[i].clear();
	}
	int a,b,val;
	for(int i=0;i<m;i++)
	{
		scanf("%d%d%d",&a,&b,&val);
		ans1[a].push_back({b,val});
		ans2[b].push_back({a,val});
	}
	
	int ans=-1;
	di(x);
	for(int i=1;i<=n;i++)
		d2[i]=d1[i];

	di2(x);
	
	for(int i=1;i<=n;i++)
	{
		ans=max(ans,d1[i]+d2[i]);	
	} 
	
	cout<<ans<<endl;
	return 0;
}

就是上面这个代码时间更少。

发布了123 篇原创文章 · 获赞 83 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/tsam123/article/details/89739059