4.犯罪团伙

阅读: 评论:0

4.犯罪团伙

4.犯罪团伙

  1. 4. 犯罪团伙

【题目描述】

此题必须采用邻接表的存储结构,建立图的存储,然后采用DFS遍历实现求解。否则不给分。

警察抓到了 n 个罪犯,警察根据经验知道他们属于不同的犯罪团伙,却不能判断有多少个团伙,但通过警察的审讯,知道其中的一些罪犯之间相互认识,已知同一犯罪团伙的成员之间直接或间接认识。有可能一个犯罪团伙只有一个人。请你根据已知罪犯之间的关系,确定犯罪团伙的数量。已知罪犯的编号从 1 至 n。

【输入】

第一行:n(<=1000,罪犯数量),第二行:m(<5000,关系数量)以下若干行:每行两个数:I 和 j,中间一个空格隔开,表示罪犯 i 和罪犯 j 相互认识。

【输出】

一个整数,犯罪团伙的数量。

【样例输入】

11

8

1 2

4 3

5 4

1 3

5 6

7 10

5 10

8 9

【输出】

3

#include <bits/stdc++.h>
using namespace std;
int i, j, c;
int visited[2000];
struct edgenode
{int adjvex;edgenode *next;
};
typedef struct vertexnode
{edgenode *firstedge;
} adjlist[2000];
typedef struct
{adjlist adj;int numV, numE;
} graph;
void create(graph *g)
{cin >> g->numV >> g->numE;for (i = 0; i < g->numV; i++)g->adj[i].firstedge = NULL;for (int k = 0; k < g->numE; k++){cin >> i >> j;edgenode *e = new edgenode;e->adjvex = j;e->next = g->adj[i].firstedge;g->adj[i].firstedge = e;edgenode *q = new edgenode;q->adjvex = i;q->next = g->adj[j].firstedge;g->adj[j].firstedge = q;}
}
void dfs(graph *g, int i)
{edgenode *p;visited[i] = 1;p = g->adj[i].firstedge;while (p){if (!visited[p->adjvex])dfs(g, p->adjvex);p = p->next;}
}
void tra(graph *g)
{int v;c = 0;for (v = 1; v <= g->numV; v++)visited[v] = 0;for (v = 1; v <= g->numV; v++)if (!visited[v]){c++;dfs(g, v);}
}
int main()
{graph g;create(&g);tra(&g);cout << c;
}

本文发布于:2024-02-01 11:29:37,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170675817636283.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:团伙
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23