判断图的连通子图个数

本文介绍了一种使用深度优先搜索(DFS)算法求解无向图中连通子图数量的方法。通过遍历图的每个节点并利用DFS进行深度探索,可以有效地计算出图中不相交连通部分的数量。代码实现使用了邻接矩阵来存储图的结构,并详细展示了如何通过DFS算法遍历未访问过的节点,从而得出连通子图的具体数目。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目要求

给定一个具有n个顶点、m条边的无向图G,假设项点的编号为1-n。基于深度优先搜索算法,编写程序
求无向图G连通子图的个数。
输入格式:
第一行两个整数n, m,分别表示图G的顶点数和边的数量。
下面m行的每-行有两个整数a和b,分别表示顶点a和顶点b有一条边相连。
输出格式:
输出一个整数,表示图G中连通子图的数量。
输入样例:
5 3
1 2
1 3
4 5
输出样例:
2

思路

由于图的深度优先遍历算法对n个节点调用之前会判断该节点是否遍历过,如果已遍历就跳过,否则调用DFS算法,所以DFS算法的调用次数就是图中联通子图的个数。

代码实现

#include <stdio.h>
#define MAXNUM 1000
int Group[MAXNUM];			//记录图中节点是否被访问过
int dist[MAXNUM][MAXNUM];	//通过邻接矩阵保存图
void DFS(int i, int n);
int main()
{
	int n, m, p, q, k = 0;
	for (int i = 0; i < MAXNUM; i++)
	{
		for (int j = 0; j < MAXNUM; j++)
			dist[i][j] = 0;				//初始化邻接矩阵,初始值为0
		Group[i] = 0;					//同上
	}
	scanf("%d%d", &n, &m);			//获取图的节点数n,和边数m
	for (int i = 0; i < m; i++)
	{
		scanf("%d%d", &p, &q);
		dist[p-1][q-1] = 1;			//如果节点1和节3相连 则另dist[1][3]和dist[3][1]的值为1
		dist[q-1][p-1] = 1;
	}
	for (int i = 0; i < n; i++)
	{
		if (Group[i] != 1)
		{
			DFS(i, n);
			k++;				//执行一次DFS就是k的值自增1,
		}
	}
	printf("%d", k);
	system("pause");
	return 0;
}
void DFS(int i,int n)
{
	Group[i] = 1;
	for (int j = 0; j < n; j++)
	{
		if (dist[i][j] == 1)
			if (Group[j] != 1)
				DFS(j, n);
	}
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

举个锤子²³³³

有钱的捧个钱场,没钱的借去

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值