【SSL_P1759】求连通分量

这篇博客主要介绍了如何求解图的连通分量问题,提供了五种不同的算法方法,包括深度优先搜索(DFS)配合邻接矩阵和邻接表,以及广度优先搜索(BFS)同样结合邻接矩阵和邻接表,其中最后一种使用了queue(队列)。文章还包含了输入输出格式和样例,适合学习图论和算法的读者。

求连通分量


题目链接:求连通分量

题目描述

求一个图的连通分量
在这里插入图片描述

输入格式

输入一个数n(n<=100)表示顶点数,下面每行输入两个整数,表示一条边的两个顶点,输入两个0表示结束。

输出格式

一个整数,为这个图的连通分量。

输入输出样例

输入

8
6 3
1 2
2 5
5 4
4 1
8 7
0 0

输出

3

解题思路

这道题方法有很多种,在老师的要求下作者写了5种方法,如果有不太清楚的地方望各位海涵

①深度优先搜索+邻接矩阵

#include<iostream>
using namespace std;
int n,a[110][110],b[110],t,maxn;
void dfs(int now,int star)//深度优先搜索
{
	if(b[now])
		return;
	b[now]=star;
	for(int i=1;i<=n;i++)
		if(a[now][i])
			dfs(i,star);
}
int main()
{
	cin>>n; 
	int x,y;
	cin>>x>>y;
	if(!(x&&y))//特殊判断
	{
		cout<<1<<endl;
		return 0;
	}
	while(x||y)//输入
	{
		a[x][y]=1;
		a[y][x]=1;
		cin>>x>>y;
	}
	for(int i=1;i<=n;i++)
	{
		dfs(i,i);
		int s=0;
		for(int j=1;j<=n;j++)
			if(b[j]==i)
				s++;
		if(s>maxn)
			maxn=s;
	}
	cout<<maxn<<endl;
}

②深度优先搜索+邻接表

#include<iostream>
using namespace std;
int n,b[110],maxn,ans,hd[110],tot;
struct abc{
	int next,to,now;
}a[1100110];
void add(int x,int y)//插入邻接表
{
	tot++;
	a[tot].now=x;
	a[tot].to=y;
	a[tot].next=hd[x];
	hd[x]=tot;//标记与这个点相连的上一条边
}
void dfs(int now)//深度优先搜索
{
	b[now]=1;//标记
	for(int j=hd[now];j;j=a[j].next)
		if(!b[a[j].to])
		{
			ans++;
			dfs(a[j].to);
		}
}
int main()
{
	cin>>n;
	int x,y;
	cin>>x>>y;
	while(x&&y)//输入
	{
		add(x,y);
		add(y,x);
		cin>>x>>y;
	}
	for(int i=1;i<=n;i++)
	{
		if(!b[i])
		{
			ans=0;
			dfs(i);
			if(ans>maxn)
				maxn=ans;
		}
	}
	cout<<maxn+1<<endl;//还要加上自身的点
}

③广度优先搜索+邻接矩阵

#include<iostream>
using namespace std;
int n,a[110][110],b[110],t,maxn,hd=0,tl=1;
struct abc{
	int now,star;
}f[110];
int main()
{
	cin>>n; 
	int x,y;
	cin>>x>>y;
	if(!(x&&y))
	{
		cout<<1<<endl;
		return 0;
	}
	while(x||y)
	{
		a[x][y]=1;
		a[y][x]=1;
		cin>>x>>y;
	}
	for(int i=1;i<=n;i++)
	{
		if(!b[i])
		{
			tl=1;
			hd=0;
			f[1].now=i;
			while(hd<tl)
			{
				hd++;
				for(int j=1;j<=n;j++)
				{
					if(a[f[hd].now][j]&&!b[j])
					{
						b[j]=1;
						tl++;
						f[tl].now=j;
					}
				}
			}
			if(tl>maxn)
				maxn=tl;
		}
	}
	cout<<maxn-1<<endl;
}

④广度优先搜索+邻接表

#include<iostream>
using namespace std;
int b[110],n,f[100010],tot,maxn,hd[100010];
struct abc{
	int next,to,now;
}a[1100110];
void add(int x,int y)
{
	tot++;
	a[tot].now=x;
	a[tot].to=y;
	a[tot].next=hd[x];
	hd[x]=tot;
}
int main()
{
	int x,y;
	cin>>n>>x>>y;
	while(x&&y)
	{
		add(x,y);
		add(y,x);
		cin>>x>>y;
	}
	for(int i=1;i<=n;i++)
	{
		if(!b[i])
		{
			int tl=1;
			int head=0;
			f[1]=i;
			while(head<tl)
			{
				head++;
				for(int j=hd[f[head]];j;j=a[j].next)
				{
					
					if(!b[a[j].to])
					{
						b[a[j].to]=1;
						tl++;
						f[tl]=a[j].to;
					}
				}
			}
			if(tl>maxn)
				maxn=tl;
		}
	}
	cout<<maxn-1<<endl;
}

⑤广度优先搜索+邻接表+queue(队列)

#include<iostream>
#include<queue>
using namespace std;
int b[110],n,tot,maxn,hd[100010];
struct abc{
	int next,to,now;
}a[1100110];
void add(int x,int y)
{
	tot++;
	a[tot].now=x;
	a[tot].to=y;
	a[tot].next=hd[x];
	hd[x]=tot;
}
int main()
{
	int x,y;
	cin>>n>>x>>y;
	while(x&&y)
	{
		add(x,y);
		add(y,x);
		cin>>x>>y;
	}
	for(int i=1;i<=n;i++)
	{
		if(!b[i])
		{
			int ans=0;
			queue<int>f;
			f.push(i);
			while(f.size())
			{
				for(int j=hd[f.front()];j;j=a[j].next)
				{
					if(!b[a[j].to])
					{
						b[a[j].to]=1;
						f.push(a[j].to);
						ans++;
					}
				}
				f.pop();
			}
			if(ans>maxn)
				maxn=ans;
		}
	}
	cout<<maxn<<endl;
}

后面的三个作者都没有加标,因为大部分和上面差不多,最后一个作者也不太懂

int ssl_init(struct tp_ssl *ssl, const struct tls_root_ctx *ssl_ctx, int is_server, int is_cwmp) #else int ssl_init(struct tp_ssl *ssl, const struct tls_root_ctx *ssl_ctx, int is_server) #endif /* INCLUDE_HTTP_SSL_MIN_TLS1_2 */ { int ret = -1; const char *pers = "tp_ssl"; ssl_log(SSL_DEBUG, "enter %s", __FUNCTION__); if (NULL == ssl || NULL == ssl_ctx) return -1; memset(ssl, 0, sizeof(struct tp_ssl)); ssl_init_debug_level(); ssl_init_timeout(); mbedtls_ctr_drbg_init(&ssl->ctr_drbg); mbedtls_entropy_init(&ssl->entropy); if ((ret = mbedtls_ctr_drbg_seed(&ssl->ctr_drbg, mbedtls_entropy_func, &ssl->entropy, (const unsigned char *) pers, strlen(pers))) != 0) { ssl_log(SSL_ERROR, "mbedtls_ctr_drbg_seed returned %d\n", ret ); goto exit; } /* Initialise SSL config */ mbedtls_ssl_config_init(&ssl->ssl_config); if ((ret = mbedtls_ssl_config_defaults(&ssl->ssl_config, ssl_ctx->endpoint, MBEDTLS_SSL_TRANSPORT_STREAM, MBEDTLS_SSL_PRESET_DEFAULT)) != 0) { ssl_log(SSL_ERROR, "mbedtls_ssl_config_defaults returned %d\n", ret ); goto exit; } mbedtls_ssl_conf_rng(&ssl->ssl_config, mbedtls_ctr_drbg_random, &ssl->ctr_drbg); mbedtls_ssl_conf_dbg(&ssl->ssl_config, tp_debug, stdout); mbedtls_ssl_cache_init(&ssl->cache); mbedtls_ssl_conf_session_cache(&ssl->ssl_config, &ssl->cache, mbedtls_ssl_cache_get, mbedtls_ssl_cache_set); mbedtls_ssl_conf_ciphersuites(&ssl->ssl_config, g_ciphersuite); mbedtls_ssl_conf_ca_chain(&ssl->ssl_config, ssl_ctx->ca_chain, NULL); if ((ret = mbedtls_ssl_conf_own_cert(&ssl->ssl_config, ssl_ctx->crt_chain, ssl_ctx->priv_key)) != 0) { ssl_log(SSL_ERROR, "mbedtls_ssl_conf_own_cert returned %d\n", ret ); goto exit; } if (!is_server) { mbedtls_ssl_conf_verify(&ssl->ssl_config, verify_callback, NULL); mbedtls_ssl_conf_authmode(&ssl->ssl_config, MBEDTLS_SSL_VERIFY_OPTIONAL); } #ifdef INCLUDE_IMDA mbedtls_ssl_conf_min_version(&ssl->ssl_config, MBEDTLS_SSL_MAJOR_VERSION_3, MBEDTLS_SSL_MINOR_VERSION_3); #else #ifdef INCLUDE_HTTP_SSL_MIN_TLS1_2 if (1 != is_cwmp) { mbedtls_ssl_conf_min_version(&ssl->ssl_config, MBEDTLS_SSL_MAJOR_VERSION_3, MBEDTLS_SSL_MINOR_VERSION_3); } else #endif /* INCLUDE_HTTP_SSL_MIN_TLS1_2 */ { mbedtls_ssl_conf_min_version(&ssl->ssl_config, MBEDTLS_SSL_MAJOR_VERSION_3, MBEDTLS_SSL_MINOR_VERSION_1); } #endif /* INCLUDE_IMDA */ mbedtls_ssl_conf_max_version(&ssl->ssl_config, MBEDTLS_SSL_MAJOR_VERSION_3, MBEDTLS_SSL_MINOR_VERSION_3); /* Initialise SSL context */ ssl->ctx = (mbedtls_ssl_context*)malloc(sizeof(mbedtls_ssl_context)); if (NULL == ssl->ctx) goto exit; mbedtls_ssl_init(ssl->ctx); if (mbedtls_ssl_setup(ssl->ctx, &ssl->ssl_config) != 0) { ssl_log(SSL_ERROR, "mbedtls_ssl_setup failed"); return -1; } if (is_server) { ssl->endpoint = MBEDTLS_SSL_IS_SERVER; } else { if (ssl_ctx->verify_cn) { mbedtls_ssl_set_hostname(ssl->ctx, ssl_ctx->verify_cn); ssl->verify_cn = 1; } if (ssl_ctx->verify_time) { ssl->verify_time = 1; } ssl->endpoint = MBEDTLS_SSL_IS_CLIENT; } ssl_init_stream(&ssl->stream); ret = 0; exit: ssl_log(SSL_DEBUG, "leave %s ret=%d", __FUNCTION__, ret); return ret; }这里有加载私钥的过程吗
最新发布
10-28
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值