社区讨论

救救孩子我吧《P1821 [USACO07FEB] Cow Party S》玄关

P1821[USACO07FEB] Cow Party S参与者 4已保存回复 8

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
8 条
当前快照
1 份
快照标识符
@lyi0699j
此快照首次捕获于
2024/07/12 09:12
2 年前
此快照最后确认于
2024/07/12 10:46
2 年前
查看原帖

求帮助

本人不会dijkstra
C
#include<bits/stdc++.h>
using namespace std;
const int N=114514;
int n,m,x;
int h[N],e[N],ne[N],w[N],idx;
int dist[N];
bool st[N];
void add(int a,int b,int c){
	e[idx]=b,ne[idx]=h[a],w[idx]=c,h[a]=idx++;
}
void dijkstra(){
	memset(dist,0x3f,sizeof(dist));
	dist[1]=0;
	for(int i=0;i<n;i++){
		int t=-1;
		for(int j=1;j<=n;j++){
			if(!st[j] && (t==-1 || dist[t]>dist[j]))t=j;
		}
		st[t]=true;
		for(int j=h[t];~j;j=ne[j]){
			int y=e[j];
			dist[y]=min(dist[y],dist[j]+w[t]);
		}
	}
}
int main(){
	memset(h,-1,sizeof(h));
	cin>>n>>m>>x;
	int q,y,z;
	while(m--){
		cin>>q>>y>>z;
		add(q,y,z);
	}
	dijkstra();
	int ans=-101010;
	for(int i=1;i<=n;i++){
		if(dist[i]!=0x3f3f3f3f)ans=max(ans,dist[i]);
	}
	cout<<ans;
	return 0;
}

回复

8 条回复,欢迎继续交流。

正在加载回复...