c++图论基础(2)

目录

图的存储方式:

邻接矩阵:

代码实现:

邻接表:

代码实现:

邻接矩阵邻接表对比:

带权图:

邻接矩阵存储:

邻接表存储(代码实现):


图的存储方式:

邻接矩阵:

无向图的邻接矩阵是对称的,2是自环

用来计算顶点的入度和出度,入度看行,出度看列

代码实现:
cpp 复制代码
int G[n][n];
memset(G,0,sizeof(G));  //初始化数组0 
G[u][v]=G[v][u]=1;//插入无向边
G[u][v]=1;//插入有向边

邻接表:

当数据中0较多,比较占用内存空间,可以考虑用邻接表

每一行第一列表示的是最外层vector数组的下标

代码实现:
cpp 复制代码
//用二维动态数组来存储邻接表
#include<iostream>
#include<vector>
using namespace std;
int main(){
	vector<int>G[11];  
	int m;
	cin>>m;//m条边
	for(int i=0;i<m;i++){
		int a,b; //从顶点a指向b的边
		cin>>a>>b;
		G[a].push_back(b);
		//G[b].push_back(a);存无向图a与b互换
	}
	for(int i=1;i<=m;i++){
		cout<<i<<" ";
		for(int j=0;j<G[i-1].size();j++){
			cout<<G[i][j]<<" ";
		}cout<<endl;
	}
	return 0;
}

邻接矩阵邻接表对比:

带权图:

边的权值简称边权

邻接矩阵存储:

邻接表存储(代码实现):

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;
struct Node{
	int v,w;
};
vector<Node>G[11];//二维动态数组存储
void insert1(int u,int v,int w){
	Node temp;
	temp.v=v;
	temp.w=w;
	G[u].push_back(temp);
} 
void insert2(int u,int v,int w){
	insert1(u,v,w);
	//insert1(v,u,w);如果要存无向图 
}
void input(){
	int m;
	cin>>m;//10  假设要存入的边为10
	for(int i=0;i<m;i++){
		int u,v,w;
		cin>>u>>v>>w; //从u指向v的有向边,边权w
		insert2(u,v,w);
	}
}
void output(){    
	for(int i=1;i<=10;i++){
		for(int j=0;j<G[i].size();j++){
			cout<<i<<" "<<G[i][j].v<<" "<<G[i][j].w<<endl;
		}
	}
}
int main(){
	input();
	output();
	return 0;
}
相关推荐
软件开发技术局43 分钟前
撕碎QT面具(8):对控件采用自动增加函数(转到槽)的方式,发现函数不能被调用的解决方案
开发语言·qt
周杰伦fans2 小时前
C#中修饰符
开发语言·c#
yngsqq2 小时前
c# —— StringBuilder 类
java·开发语言
赔罪3 小时前
Python 高级特性-切片
开发语言·python
专注VB编程开发20年3 小时前
除了 EasyXLS,加载和显示.xlsx 格式的excel表格,并支持单元格背景色、边框线颜色和粗细等格式化特性
c++·windows·excel·mfc·xlsx
分别努力读书3 小时前
acm培训 part 7
算法·图论
子豪-中国机器人4 小时前
2月17日c语言框架
c语言·开发语言
夏天的阳光吖4 小时前
C++蓝桥杯基础篇(四)
开发语言·c++·蓝桥杯
oioihoii4 小时前
C++17 中的 std::to_chars 和 std::from_chars:高效且安全的字符串转换工具
开发语言·c++
张胤尘4 小时前
C/C++ | 每日一练 (2)
c语言·c++·面试