有关vector的存图用法

用vector存图

const int N=1e5+10;
vector<int> G[N];
void addedge(int u,int v){
	G[u].push_back(v);
	G[v].push_back(u);
}

用vector存图(有边权)

const int N=1e5+10;
struct Edge{
	int v,w;
};
Edge make_Edge(int v,int w){
	Edge cur;cur.v=v;cur.w=w;return cur;
}
vector<Edge> G[N];
void addedge(int u,int v,int w){
	G[u].push_back(make_Edge(v,w));
	G[v].push_back(make_Edge(u,w));
}

Pair:
vector<pair<int,int> >G[N];
void addedge(int u,int v,int w){
	G[u].push_back(make_pair(v,w));
	G[v].push_back(make_pair(u,w));
}
发布了121 篇原创文章 · 获赞 3 · 访问量 3395

猜你喜欢

转载自blog.csdn.net/qq_45585519/article/details/103289506