SPFA板子
时间复杂度最多O(n*m)
可用来判负环,以及带负边权的最短路
struct edge{
int v;int w;
};
vector<edge>e[maxn];
int d[maxn],cnt[maxn],vis[maxn];
bool spfa(int s){
queue<int>q;
memset(d,inf,sizeof(d));d[s]=0;
vis[s]=1;q.push(s);
while(!q.empty()){
int u=q.front();q.pop();vis[u]=0;
for(auto ed:e[u]){
int v=ed.v,w=ed.w;
if(d[v]>d[u]+w){
d[v]=d[u]+w;
cnt[v]=cnt[u]+1;
if(cnt[v]>=n)return true;
if(!vis[v]){
q.push(v);
vis[v]=1;
}
}
}
}
return false;
}

浙公网安备 33010602011771号