社区讨论

样例爆零求条

P4568[JLOI2011] 飞行路线参与者 1已保存回复 0

讨论操作

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

当前回复
0 条
当前快照
1 份
快照标识符
@miylgg27
此快照首次捕获于
2025/12/09 21:06
2 个月前
此快照最后确认于
2025/12/12 19:10
2 个月前
查看原帖
个人觉得可能是建图出了问题
但是看不出是哪里
求各位dalao帮看看QAQ
CPP
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll n,m,k,s,t;
struct edge{
	ll v,w;
};vector<edge> G[50010];
struct node{
	ll u,dis;
	friend bool operator <(node x,node y){
		return x.dis>y.dis;
	} 
};priority_queue<node> q;
ll dis[10010],vis[10010];
void dijkstra(){
	for(int i=1;i<=n;i++) dis[i]=1e18;
	dis[s]=0;
	q.push({s,0});
	while(!q.empty()){
		node op=q.top();
		q.pop();
		ll u=op.u;
		
		if(vis[u]) continue;
		vis[u]=1;
		
		for(int i=0;i<G[u].size();i++){
			ll v=G[u][i].v,w=G[u][i].w;
			if(dis[v]>dis[u]+w){
				dis[v]=dis[u]+w;
				q.push({v,dis[v]}); 
			}
		} 
	}
} 
int main(){
	cin>>n>>m>>k>>s>>t;
	for(int i=1;i<=m;i++){
		int u,v,w;
		cin>>u>>v>>w;
		G[u].push_back({u,w});
		G[v].push_back({v,w});
		for(int j=1;j<=k;j++){
			G[u+j*n].push_back({v+j*n,w});
			G[v+j*n].push_back({u+j*n,w});
			G[u+(j-1)*n].push_back({v+j*n,0});
			G[v+(j-1)*n].push_back({u+j*n,0});
		}
	}
	for(int i=1;i<=k;i++) G[t+(i-1)*n].push_back({t+i*n,0});
	dijkstra();
	cout<<dis[t+n*k];
	return 0;
}


回复

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

正在加载回复...