无向图的创建和深度优先遍历,广度优先遍历

本文介绍了如何使用邻接链表实现无向图,并提供了深度优先遍历和广度优先遍历的代码示例。邻接矩阵和邻接表是图的两种常见表示方式,邻接链表更节省空间。示例代码未经严格测试,仅作为基础实现参考。
摘要由CSDN通过智能技术生成

声明:下面的代码只是一个最基础的实现,没有经过严格的测试

图有两种表示方式,一种是邻接矩阵(二维数组),另一种是邻接表(数组+链表)

下面的例子是针对于邻接链表实现的

 

111

上面的两幅图,第一副是无向图,第二幅是用邻接链表表示的无向图。

代码如下:

/**
 * 图用来表示多对多的关系,数组和链表有前驱和后继,可以认为是一对一的关系。树是一对多的关系。
 * 图的基本元素:顶点,边,路径,有向图,无向图,带权图(又称之为网),其他概念参考:https://www.cnblogs.com/songgj/p/9107797.html
 * 邻接顶点:与当前顶点相连的顶点称之为邻接顶点。寻找邻接顶点的过程是先近后远
 *
 */
public class Graph<E> {
    //存储所有的顶点
    private List<VertexNode> vertexList;
    /**
     * 用二维数组表示图的邻接矩阵,如果图中有n个顶点,则创建 n X n 的矩阵来表示没两个顶点之间的连接情况。
     * 如果矩阵的元素为1,则该元素对应的顶点之间有边,如果为0,则无连接
     */
    private int[][] edges;
    //表示边的数目
    private int numOfEdges;

    public static void main(String[] args) {

        //创建一个无向图
        String[] vertexArr={"A","B","C","D","E"};
        Graph graph = new Graph(vertexArr.length);
        for (String s : vertexArr) {
            graph.insertVertex(new VertexNode(s));
        }

        // 添加边: A-B, A-C , B-C,B-D,B-E
        graph.insertEdge(0,1,1);
        graph.insertEdge(0,2,1);
        graph.insertEdge(1,2,1);
        graph.insertEdge(1,3,1);
        graph.insertEdge(1,4,1);

        /**
         * 打印的值:
         * [0, 1, 1, 0, 0]
         * [1, 0, 1, 1, 1]
         * [1, 1, 0, 0, 0]
         * [0, 1, 0, 0, 0]
         * [0, 1, 0, 0, 0]
         */
        graph.showGraph();

        /**
      
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是无向图深度优先遍历广度优先遍历的介绍和演示: 1.深度优先遍历(DFS): 深度优先遍历是一种用于遍历或搜索树或的算法。在这种搜索方法中,从根结点开始,尽可能深地搜索每个分支,直到找到目标值或无法继续为止。然后回溯到前一个结点,尝试另一条分支,直到所有结点都被访问为止。 以下是一个无向图深度优先遍历的Python代码示例: ```python # 无向图深度优先遍历 def DFS(graph, start, visited=None): if visited is None: visited = set() visited.add(start) print(start, end=' ') for next in graph[start] - visited: DFS(graph, next, visited) return visited # 无向图的邻接表表示 graph = {'A': set(['B', 'C']), 'B': set(['A', 'D', 'E']), 'C': set(['A', 'F']), 'D': set(['B']), 'E': set(['B', 'F']), 'F': set(['C', 'E'])} # 从顶点A开始遍历 print("深度优先遍历结果:") DFS(graph, 'A') ``` 输出结果为:A B D E F C 2.广度优先遍历(BFS): 广度优先遍历是一种用于遍历或搜索树或的算法。在这种搜索方法中,从根结点开始,逐层遍历每个分支,直到找到目标值或无法继续为止。 以下是一个无向图广度优先遍历的Python代码示例: ```python # 无向图广度优先遍历 def BFS(graph, start): visited, queue = set(), [start] visited.add(start) while queue: vertex = queue.pop(0) print(vertex, end=' ') for next in graph[vertex] - visited: visited.add(next) queue.append(next) # 无向图的邻接表表示 graph = {'A': set(['B', 'C']), 'B': set(['A', 'D', 'E']), 'C': set(['A', 'F']), 'D': set(['B']), 'E': set(['B', 'F']), 'F': set(['C', 'E'])} # 从顶点A开始遍历 print("广度优先遍历结果:") BFS(graph, 'A') ``` 输出结果为:A B C D E F

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值