目 录CONTENT

文章目录

无向图——深搜与广搜

不争
2024-01-02 / 0 评论 / 0 点赞 / 52 阅读 / 2765 字

无向图——深搜与广搜

image-20220508085425808

输入:

5 5
1 2
1 3
1 5
2 4
3 5

dfs题解:

#include<stdio.h>
int book[101], sum, n, e[101][101];
void dfs(int cur) // cur是当前所在的顶点编号
{
    int i;
    printf("%d ", cur);
    sum ++; // 每访问一个顶点,sum就加1
    if (sum == n) return ; //所有顶点都已经访问过则直接退出
    for (i = 1 ; i <= n ; i ++){ //从1号顶点到n号顶点依次尝试,看哪些顶点与当前顶点cur有边相连
        //判断当前顶点cur到顶点i是否有边,并判断顶点i是否已经访问过
        if(e[cur][i] == 1 && book[i] == 0){
            book[i] = 1;//标记顶点i已经访问过
            dfs(i);
        }
    }
    return ;
}

int main(){
    int i,j,m,a,b;
    scanf("%d %d", &n, &m);
    //初始化二维矩阵
    for (i = 1; i <= n; i ++){
        for (j = 1 ; j <= m ; j ++){
            if (i == j) e[i][j] = 0;
            else e [i][j] = 99999999;
        }
    }
    //读入顶点之间的边
    for (i = 1 ; i <= m ; i ++){
        scanf("%d %d",&a, &b);
        e[a][b] = 1;
        e[b][a] = 1; //这里是无向图,所以需要将e[b][a] 也赋为1
    }

    //从1号城市出发
    book[1] = i; // 标记1号顶点已访问
    dfs(1); // 从1号顶点开始遍历
    puts("\n");

    return 0;
}

运行结果:

image-20220508085559064

bfs题解:

#include<stdio.h>
int main(){
    int i, j, n, m, a, b, cur, book[101] = {0}, e[101][101];
    int que[10001], head, tail;
    scanf("%d %d",&n, &m);
    //初始化二维矩阵
    for (i = 1; i <=n ; i ++){
        for (j = 1 ; j <= n ; j ++){
            if (i == j) e[i][j] = 0;
            else e[i][j] = 99999999;
        }
    }

    //读入顶点之间的边
    for (i = 1 ; i <= m ; i ++){
        scanf("%d %d", &a, &b);
        e[a][b] = 1;
        e[b][a] = 1; //这里是无向图,所以需要将e[a][b]也赋为1
    }

    //队列初始化
    head = 1;
    tail = 1;

    //从1号顶点开始出发,将1号顶点加入队列
    que[tail] = 1;
    tail++;
    book[1] = 1; // 标记1号顶点已访问

    //当队列不为空的时候循环
    while (head < tail){
        cur = que[head]; // 当前正在访问的顶点编号
        for (i = 1 ; i <= n ; i ++){
            //判断从顶点cur到顶点的i有边,并判断顶点i没有被访问过
            if (e[cur][i] == 1 && book[i] == 0){
                que[tail] = i;
                tail ++;
                book[i] = 1; // 标记顶点i已访问过
            }
            //如果tail大于n,则表明所有顶点都已经被访问过
            if (tail > n) break;
        }
        head ++;
    }
    for (i = 1 ; i < tail ; i ++){
        printf("%d ",que[i]);
    }
    return 0;
}

运行结果:

image-20220508093901982

0

评论区