当前位置: 首页 > news >正文

算法竞赛备赛——【图论】链式前向星

图论

图的存储方式:

通用的三种:邻接矩阵、邻接表、边集数组

有向图:十字链表

无向图:多重邻接表

刷题常用:邻接矩阵、链式前向星(邻接表变形)

链式前向星

算法题常用:

邻接矩阵、二维vector模拟邻接表、链式前向星

n个点 m条边 m>nlogn算稠密图 m<nlogn算稀疏图

稠密图:邻接矩阵 O(n^2)

稀疏图:邻接表---->二维vector(无权)/链式前向星(带权) O(n+m) (边多了连的多不合适)

无权无向图

#include <bits/stdc++.h>
using ll=long long;
using namespace std;
const int N=5e4+5; 

//无权无向图 ---->二维vector 模拟邻接表 多用于存无权图
int n,m;

vector<vector<int>> g;
int v[105];

void dfs(int x){
	if(v[x]) return;
	printf("%d ",x); 
	v[x]=1;
	int y;
	for(int i=0;i<g[x].size();++i){
		y=g[x][i];
		dfs(y);
	}
}

int main(){
	cin>>n>>m;
	g.resize(n+1);
	int x,y;
	for(int i=1;i<=m;++i){
		cin>>x>>y;
		g[x].push_back(y);
		g[y].push_back(x);
	}
	for(int i=1;i<=n;++i){
		if(v[i]==0) dfs(i);
	}
	return 0;
}
/*输入样例 
4 5
1 2
1 4
2 3
2 4
3 4
*/

有权无向图

#include <bits/stdc++.h>
using ll=long long;
using namespace std;
const int N=5e4+5; 

//带权无向图 ---->链式向前星 ----> 静态链表模拟邻接表 
int n,m;
int head[105]; 
int v[105]; 
struct edge{
	int to;//该边的终点 
	int w;//该边的权值 
	int nex;//和该边同起点的另一条边的下标 
}e[10005];//边的条数最大为n*(n-1) 

int cnt=0;
void add(int x,int y,int wi){
	//x--wi->y
	e[cnt].to=y;
	e[cnt].w=wi;
	//模拟链表的头插法 
	e[cnt].nex=head[x];
	head[x]=cnt;
	
	cnt++;
}

void dfs(int x){
	if(v[x]) return ;
	printf("%d ",x);
	v[x]=1;
	for(int i=head[x];i!=-1;i=e[i].nex){//枚举x所有出边 找x的临界点 
		int y=e[i].to;
		dfs(y); 
	}
}

int main(){
	memset(head,-1,sizeof head);
	cin>>n>>m;
	int x,y,wi;
	for(int i=1;i<=m;++i){
		cin>>x>>y>>wi;
		add(x,y,wi);
		add(y,x,wi);
	}
	for(int i=1;i<=n;++i){
		if(v[i]==0) dfs(i);
	}
	return 0;
}
/*输入样例 
4 5
1 2 5
1 4 3
2 3 8
2 4 12
3 4 9
*/

相关文章:

  • 回表, 覆盖索引,索引下推简述
  • 混凝土强度预测工程实践
  • ASRank: Zero-Shot Re-Ranking with Answer Scent for DocumentRetrieval
  • 蓝桥杯_LITS游戏 俄罗斯方块 模拟 暴力 搜索 DFS 剪纸 枚举
  • TRPO和PPO算法详解
  • C++单例模式
  • 让ChatGPT用DeepReaserch指导进行学术写作
  • vue猜词游戏
  • 进程内存分布--之理论知识
  • 中钧科技通过数字赋能,编织“数字互联网”助力数字化进程!
  • SSM整合实战
  • 手搓多模态-03 顶层和嵌入层的搭建
  • 玄机-应急响应-入侵排查
  • 图解AUTOSAR_SWS_FlexRayARTransportLayer
  • 性能问题排查工具介绍
  • 移动应用开发实验室2024二面纳新题复盘
  • 【家政平台开发(20)】系统监控与日志管理设计:稳固运行的基石
  • 【内网安全】DHCP 饿死攻击和防护
  • [特殊字符] 驱动开发硬核特训 · Day 4
  • Vue3响应式引擎解密:从依赖追踪到性能调优的深度之旅
  • 新时代政府网站建设/世界网站排名查询
  • 昆山哪里有人做网站/国产长尾关键词拘挖掘
  • 电脑网站建设在哪里/seo公司外包
  • 武汉营销型网站建设/免费大数据查询平台
  • 电影网站建设规划书/怎么提高关键词搜索排名
  • 公司建设网站需求/google adsense