蒟蒻求助
查看原帖
蒟蒻求助
181037
ysmlwudia楼主2020/11/1 15:16
#include<iostream>
#include<stdio.h>
#include<queue>
#include<algorithm>
#include<string.h>
#define ll long long
using namespace std;
int n,m,s,ed,dis[105][105],last[105],tot,ans,vis[105][105],maxcost,mintim;
struct edge{
	int prev,to,val,tim;
}e[605];
void add(int a,int b,int c,int d){
	e[++tot]=edge{last[a],b,c,d};
	last[a]=tot;
}
queue< pair<int,int> >q;
void spfa(){
	q.push(make_pair(s,0));
	vis[s][0]=1;
	memset(dis,0x3f,sizeof(dis));
	dis[s][0]=0;
	while(!q.empty()){
		int u=q.front().first,cost=q.front().second;
		q.pop();
		vis[u][cost]=0;
		for(int i=last[u];i;i=e[i].prev){
			int v=e[i].to;
			if(dis[u][cost]+e[i].tim<dis[v][cost+e[i].val]){
				dis[v][cost+e[i].val]=dis[u][cost]+e[i].tim;
				if(!vis[v][cost+e[i].val]){
					vis[v][cost+e[i].val]=1;
					q.push(make_pair(v,cost+e[i].val));
				}
			}
		}
	}
}
int main(){
	ios::sync_with_stdio(0);
	cin>>n>>m>>s>>ed;
	for(int i=1;i<=m;i++){
		int p,r,c,t;
		cin>>p>>r>>c>>t;
		add(p,r,c,t);
		add(r,p,c,t); 
		maxcost+=c;
	}
	spfa();
	mintim=200;
	for(int i=0;i<=maxcost;i++){
		if(dis[ed][i]<mintim){
			ans++;
			mintim=dis[ed][i];
		}
	}
	cout<<ans;
	return 0;
}

我真觉得没问题 样例输出3

2020/11/1 15:16
加载中...