为什么只有50分,dij调不出来
查看原帖
为什么只有50分,dij调不出来
467616
osky123456楼主2022/1/22 22:36
#include<bits/stdc++.h>
#define MAXN 20000
using namespace std;
struct edge{
	int to,next,dis;
};
edge e[MAXN];
int n,m;
unsigned long long ans=0;
int dis[MAXN<<1],vis[MAXN<<1],head[MAXN<<1],cnt;
struct node{
	int dis;
	int pos;
	bool operator<(const node &x)const{
	    return x.dis<dis;
	}
};
priority_queue<node> q;
inline void add_edge(int u,int v,int dis){
	e[++cnt].dis=dis;
	e[cnt].next=head[u];
	e[cnt].to=v;
	head[u]=cnt;
}
void dij(int s){
	dis[s]=0;
	q.push((node){0,s});
	while(!q.empty()){
		node tmp=q.top();
		q.pop();
		int x=tmp.pos,d=tmp.dis;
		if(vis[x]) continue;
		vis[x]=true;
		for(int i=head[x];i;i=e[i].next){
			int y=e[i].to;
			if(dis[y]>dis[x]+e[i].dis){
				dis[y] = dis[x] + e[i].dis;
				if(!vis[y]) q.push((node){dis[y],y});
			}
		}
	}
}
int main(){
	freopen("ceshi.in","r",stdin);
	freopen("ceshi.out","w",stdout);
	cin>>n>>m;
	for(int i=1;i<=n<<1;++i) dis[i]=0x7fffff;
	for(int i=1;i<=m;++i){
		int u,v,d;
		cin>>u>>v>>d;
		add_edge(u,v,d);
		add_edge(v+n,u+n,d);
	}
	dij(1);
	for(int i=2;i<=n;++i) ans+=dis[i];
	dij(1+n);
	for(int i=2+n;i<=n*2;++i) ans+=dis[i];
	cout<<ans;
	fclose(stdin);
	fclose(stdout);
	return 0;
}


我无语了…………

n*2是为了反图 求大佬帮一下

2022/1/22 22:36
加载中...