图(无向网)的邻接矩阵存储以及深度、广度优先遍历操作-java

/**
 * 图的邻接矩阵表示法(无向网)
 */
public class AdjacencyMatrixGraph {

    // 图的顶点数组
    char[] vexs;
    // 邻接矩阵
    int arcs[][];
    // 图中顶点和边的数量
    int vexNums,arcNums;

    // 构造方法
    public AdjacencyMatrixGraph(int n){
        this.vexs=new char[n];
        this.arcs=new int[n][n];
    }

    /**
     * 无向网的初始化
     * @param vexStr
     * @param arcStr
     */
    public void init(String vexStr,String[] arcStr){
        // 初始化顶点数组
        for (int i = 0; i < vexs.length; i++) {
            vexs[i]=vexStr.charAt(i);
            vexNums++;
        }

        // 初始化邻接矩阵,并附默认值为最大数
        for (int i = 0; i < arcs.length; i++) {
            for (int j = 0; j < arcs[i].length; j++) {
                arcs[i][j]=Integer.MAX_VALUE;
            }
        }

        // 根据边的关系给邻接矩阵赋值
        for (String s : arcStr) {
            // 顶点v1
            char v1=s.charAt(0);
            // 顶点v2
            char v2=s.charAt(2);
            // 权值
            int w=s.charAt(4)-'0';
            // 得到i,j
            int i=locateVex(v1);
            int j=locateVex(v2);

            // 设边(v1,v2)的权值为w
            arcs[i][j]=w;
            // 因为是无向网,它的邻接矩阵是对称的,所以设边(v2,v1)的对称边也为w
            arcs[j][i]=w;
            arcNums++;
        }

    }

    // 查找某一顶点在顶点数组中的下标
    private int locateVex(char v){
        for (int i = 0; i < vexs.length; i++) {
            if(v==vexs[i]){
                return i;
            }
        }
        return -1;
    }

    /**
     * 邻接矩阵的深度优先遍历,时间复杂度为O(n2)
     * 1.先访问起始点vex,再访问邻接矩阵中第vex行中的邻接点,
     * 2.对所有未访问过的邻接点递归地进行第1步操作,直至所有邻接点都被访问
     * @param vex 起点
     * @param visited 辅助数组,用以标识顶点是否被访问过
     */
    public void DFS(int vex,int[] visited){
        visited[vex]=1;
        System.out.println("访问了"+vexs[vex]);
        for (int j = 0; j < this.vexs.length; j++) {
            if(this.arcs[vex][j]!=0 && visited[j]==0){
                DFS( j, visited);
            }
        }
    }

    /**
     * 邻接矩阵的广度优先遍历
     * 1.将起始点vex入队,再将vex出队
     * 2.先遍历起始点vex的所有邻接点(在邻接矩阵中就是遍历第i行中所有有值的列),并将所有邻接点入队
     * 2.将队头的顶点元素出队,并遍历它的所有邻接点,并将所有邻接点入队
     * 3.重复上述操作,直至队列为空,此时广度优先遍历完成
     * 需要注意的时,邻接点入队需要满足2个条件:1.arcs[i][j]有值,2.顶点j未被访问过
     * @param vex 起始顶点
     * @param queue 辅助队列
     * @param visited 辅助数组
     */
    public void BFS(int vex, Queue queue, int[] visited){
        queue.add(vex);
        visited[vex]=1;
        System.out.println("访问了"+vexs[vex]);
        // 如果队列不为空
        while(!queue.isEmpty()){
            int i= (int) queue.poll();
            for (int j=0; j<arcs.length; j++){
                // 遍历第i行,如果arcs[i][j]不等于默认值,并且没有访问过,则将j顶点入队
                if(arcs[i][j]!=Integer.MAX_VALUE && visited[j]==0){
                    queue.add(j);
                    visited[j]=1;
                    System.out.println("访问了"+vexs[j]);
                }
            }
        }
    }
}

测试类:

public class Test {
    public static void main(String[] args) {
        AdjacencyMatrixGraph adjacencyMatrixGraph=new AdjacencyMatrixGraph(4);
        // 无向网的顶点集合
        String vexStr="ABCD";
        // 无向网的边集合,例如"A,B,4",A,B分别为边的两个顶点,4为此条边的权值
        String arcStr[]={"A,B,4","A,C,3","A,D,9","B,C,1","B,D,7","C,D,2"};
        adjacencyMatrixGraph.init(vexStr,arcStr);
        System.out.println("无向网初始化完成");

        System.out.println("深度优先遍历:");
        adjacencyMatrixGraph.DFS(2,new int[4]);
        System.out.println("广度优先遍历:");
        adjacencyMatrixGraph.BFS(3,new ArrayDeque(), new int[4]);
    }
}

测试类运行结果:
在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值