判断图的连通分量
2015-10-25 09:21
197 查看
图的连通分量 是指图内包含多少个连通子图;思路类似于上一篇 判断图的连通性;
/***********如果要计算是不是有环图 只要利用公式 若图中有n个点 m个连通分量 则当边的条数大于n-m 则此图为有环图**************/
#include<stdio.h>
#define M 7
void init(int map[][M]){
for(int i=0;i<M;i++){
for(int j=0;j<M;j++){
scanf("%d",&map[i][j]);
}
}
}
void show(int map[][M]){
for(int i=0;i<M;i++){
for(int j=0;j<M;j++){
printf("%d ",map[i][j]);
}printf("\n");
}
}
void prcos(int map[][M],int &sum,int &temp,int ever[]){
for(int j=0;j<M;j++){
if(map[temp][j]==1){
ever[j]=1;
sum++;
for(int i=0;i<M;i++){//找到新的1,则将此列全部设为0;表示此点已经走到过
map[i][j]=0;
}
prcos(map,sum,j,ever);
}
}
}
void main(){
int map[M][M];
init(map);
// show(map);
int ever[M]={0};
int sum=0;
int Branch=0;
while(sum<M){
Branch++;
for(int i=0;i<M;i++){
if(ever[i]==0){
ever[i]=1;
prcos(map,sum,i,ever);
// printf("%d\n",sum);
break;
}
}
}
printf("一共有%d个分支\n",Branch);
printf("一共有%d个点\n",sum);
// show(map);
}
/***********如果要计算是不是有环图 只要利用公式 若图中有n个点 m个连通分量 则当边的条数大于n-m 则此图为有环图**************/
#include<stdio.h>
#define M 7
void init(int map[][M]){
for(int i=0;i<M;i++){
for(int j=0;j<M;j++){
scanf("%d",&map[i][j]);
}
}
}
void show(int map[][M]){
for(int i=0;i<M;i++){
for(int j=0;j<M;j++){
printf("%d ",map[i][j]);
}printf("\n");
}
}
void prcos(int map[][M],int &sum,int &temp,int ever[]){
for(int j=0;j<M;j++){
if(map[temp][j]==1){
ever[j]=1;
sum++;
for(int i=0;i<M;i++){//找到新的1,则将此列全部设为0;表示此点已经走到过
map[i][j]=0;
}
prcos(map,sum,j,ever);
}
}
}
void main(){
int map[M][M];
init(map);
// show(map);
int ever[M]={0};
int sum=0;
int Branch=0;
while(sum<M){
Branch++;
for(int i=0;i<M;i++){
if(ever[i]==0){
ever[i]=1;
prcos(map,sum,i,ever);
// printf("%d\n",sum);
break;
}
}
}
printf("一共有%d个分支\n",Branch);
printf("一共有%d个点\n",sum);
// show(map);
}
相关文章推荐
- Lua和C语言的交互详解
- Lua教程(七):数据结构详解
- 解析从源码分析常见的基于Array的数据结构动态扩容机制的详解
- C#数据结构揭秘一
- 关于C语言中参数的传值问题
- 简要对比C语言中三个用于退出进程的函数
- 深入C++中API的问题详解
- 基于C语言string函数的详解
- C语言中fchdir()函数和rewinddir()函数的使用详解
- C语言内存对齐实例详解
- 使用C语言判断英文字符大小写的方法
- c语言实现的带通配符匹配算法
- C语言实现顺序表基本操作汇总
- C语言中计算正弦的相关函数总结
- 数据结构之Treap详解
- 使用C语言详解霍夫曼树数据结构
- 探讨C语言的那些小秘密之断言
- C语言实现BMP转换JPG的方法
- 深入探讨C语言中局部变量与全局变量在内存中的存放位置
- C语言查找数组里数字重复次数的方法