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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Wrong Ansewer

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值