这题怎么做?求助
题目传送门
已有代码
#include<bits/stdc++.h>
using namespace std;
#define MAXSIZE 105;
int v[MAXSIZE],w[MAXSIZE],head[MAXSIZE],next[MAXSIZE],tot=0;
int d[MAXSIZE];
void bfs(int x){
	queue<int>q;
	q.push(x);d[x]=1;
	while(!q.empty()){
		int u=q.front();
		q.pop();
		for(int i=head[u];i;i=next[i]){
			int y=v[i];
			if(d[y])continue;
			d[y]=d[u]+1;
			q.push(y);
		}
	}
}
void add_edge(int x,int y,int z){
	v[++tot]=y;
	w[tot]=z;
	next[tot]=head[x],head[x]=tot;
}
int main(){
	int n,m,a,b,c;
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		cin>>a>>b>>c;
		add_edge(a,b,c)
	}
}