社区讨论

TLE on #8 #9

P1629邮递员送信参与者 1已保存回复 0

讨论操作

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

当前回复
0 条
当前快照
1 份
快照标识符
@mm4ayn2l
此快照首次捕获于
2026/02/27 10:58
2 周前
此快照最后确认于
2026/02/28 20:15
上周
查看原帖
CPP
#include<bits/stdc++.h>
#define pr pair<int , int>
using namespace std;
priority_queue<pr , vector<pr> , greater <pr> > q;
int a,b,c,d,dis[10002],head[10001],cnt,vis[1002][1002],sum;
bool v[10001];
struct edgee{
	int to,nxt,w;
}edge[100001];
void add(int iop,int io,int i){
	cnt++;
	edge[cnt].w=i;
	edge[cnt].to=io;
	edge[cnt].nxt=head[iop];
	head[iop]=cnt;
}
void dij(int z){
	memset(dis,0x3f,sizeof dis);
	dis[z]=0;
	q.push(make_pair(0,z));
	while(!q.empty()){
		int p=q.top().second;
		q.pop();
		if(v[p]){
			continue;
		}
		v[p]=1;
		for(int j=head[p];j;j=edge[j].nxt){
			int t=edge[j].to;
			if(dis[t]>dis[p]+edge[j].w&&!v[t]){
				dis[t]=dis[p]+edge[j].w;
				q.push(make_pair(dis[t],t));
			}
		}
	}
}
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>a>>b;
	for(int i=1;i<=b;i++){
		int x,y,z;
		cin>>x>>y>>z;
		if(vis[x][y]==0){
			vis[x][y]=z;
		}else{
			vis[x][y]=min(vis[x][y],z);
		}
	}
	for(int i=1;i<=a;i++){
		for(int j=1;j<=a;j++){
			if(vis[i][j]!=0){
				add(i,j,vis[i][j]);
			}
		}
	}
	
	for(int i=2;i<=a;i++){
		memset(v,0,sizeof v);
		memset(dis,0,sizeof dis);
		dij(1); 
		sum+=dis[i];
		memset(v,0,sizeof v);
		memset(dis,0,sizeof dis);
		dij(i);
		sum+=dis[1];
	
	}
	cout<<sum;
	return 0;
}
dijkstra

回复

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

正在加载回复...