图结构展示:

实现过程:

首先,我们来看看图结构在代码中的实现。有三块逻辑:

1.图中的节点:

  1. public class GraphNode {
  2. public List<GraphEdge> edgeList = null;
  3. private String label = "";
  4. public GraphNode(String label) {
  5. this.label = label;
  6. if (edgeList == null) {
  7. edgeList = new ArrayList<GraphEdge>();
  8. }
  9. }
  10. /**
  11. * 给当前节点添加一条边
  12. * GraphNode
  13. * @param edge
  14. *          添加的边
  15. */
  16. public void addEdgeList(GraphEdge edge) {
  17. edgeList.add(edge);
  18. }
  19. public String getLabel() {
  20. return label;
  21. }
  22. }

2.图中的边:

  1. public class GraphEdge {
  2. private GraphNode nodeLeft;
  3. private GraphNode nodeRight;
  4. /**
  5. * @param nodeLeft
  6. *          边的左端
  7. * @param nodeRight
  8. *          边的右端
  9. */
  10. public GraphEdge(GraphNode nodeLeft, GraphNode nodeRight) {
  11. this.nodeLeft = nodeLeft;
  12. this.nodeRight = nodeRight;
  13. }
  14. public GraphNode getNodeLeft() {
  15. return nodeLeft;
  16. }
  17. public GraphNode getNodeRight() {
  18. return nodeRight;
  19. }
  20. }

3.把节点和边组合成一个图结构:

  1. public class MyGraph {
  2. private List<GraphNode> nodes = null;
  3. public void initGraph(int n) {
  4. if (nodes == null) {
  5. nodes = new ArrayList<GraphNode>();
  6. }
  7. GraphNode node = null;
  8. for (int i = 0; i < n; i++) {
  9. node = new GraphNode(String.valueOf(i));
  10. nodes.add(node);
  11. }
  12. }
  13. public void initGraph(int n, boolean b) {
  14. initGraph(n);
  15. GraphEdge edge01 = new GraphEdge(nodes.get(0), nodes.get(1));
  16. GraphEdge edge02 = new GraphEdge(nodes.get(0), nodes.get(2));
  17. GraphEdge edge13 = new GraphEdge(nodes.get(1), nodes.get(3));
  18. GraphEdge edge14 = new GraphEdge(nodes.get(1), nodes.get(4));
  19. GraphEdge edge25 = new GraphEdge(nodes.get(2), nodes.get(5));
  20. GraphEdge edge26 = new GraphEdge(nodes.get(2), nodes.get(6));
  21. GraphEdge edge37 = new GraphEdge(nodes.get(3), nodes.get(7));
  22. GraphEdge edge47 = new GraphEdge(nodes.get(4), nodes.get(7));
  23. GraphEdge edge56 = new GraphEdge(nodes.get(5), nodes.get(6));
  24. nodes.get(0).addEdgeList(edge01);
  25. nodes.get(0).addEdgeList(edge02);
  26. nodes.get(1).addEdgeList(edge13);
  27. nodes.get(1).addEdgeList(edge14);
  28. nodes.get(2).addEdgeList(edge25);
  29. nodes.get(2).addEdgeList(edge26);
  30. nodes.get(3).addEdgeList(edge37);
  31. nodes.get(4).addEdgeList(edge47);
  32. nodes.get(5).addEdgeList(edge56);
  33. }
  34. public void initGraph() {
  35. initGraph(8, false);
  36. }
  37. public List<GraphNode> getGraphNodes() {
  38. return nodes;
  39. }
  40. }

有了图的结构,我们就可以进行一些实际的操作了。

深度优先搜索:

  1. public class DFSearch {
  2. /**
  3. * 深度遍历
  4. * DFSearch
  5. * @param node
  6. *          当前节点
  7. * @param visited
  8. *          被访问过的节点列表
  9. */
  10. public void searchTraversing(GraphNode node, List<GraphNode> visited) {
  11. // 判断是否遍历过
  12. if (visited.contains(node)) {
  13. return;
  14. }
  15. visited.add(node);
  16. System.out.println("节点:" + node.getLabel());
  17. for (int i = 0; i < node.edgeList.size(); i++) {
  18. searchTraversing(node.edgeList.get(i).getNodeRight(), visited);
  19. }
  20. }
  21. }

广度优先搜索:

  1. public class BFSearch {
  2. /**
  3. * 广度优先搜索
  4. * BFSearch
  5. * @param node
  6. *          搜索的入口节点
  7. */
  8. public void searchTraversing(GraphNode node) {
  9. List<GraphNode> visited = new ArrayList<GraphNode>(); // 已经被访问过的元素
  10. Queue<GraphNode> q = new LinkedList<GraphNode>(); // 用队列存放依次要遍历的元素
  11. q.offer(node);
  12. while (!q.isEmpty()) {
  13. GraphNode currNode = q.poll();
  14. if (!visited.contains(currNode)) {
  15. visited.add(currNode);
  16. System.out.println("节点:" + currNode.getLabel());
  17. for (int i = 0; i < currNode.edgeList.size(); i++) {
  18. q.offer(currNode.edgeList.get(i).getNodeRight());
  19. }
  20. }
  21. }
  22. }
  23. }

运行结果:

java深度搜索与广度优先搜索的更多相关文章

  1. DFS_BFS(深度优先搜索 和 广度优先搜索)

    package com.rao.graph; import java.util.LinkedList; /** * @author Srao * @className BFS_DFS * @date ...

  2. 【js数据结构】图的深度优先搜索与广度优先搜索

    图类的构建 function Graph(v) {this.vertices = v;this.edges = 0;this.adj = []; for (var i = 0; i < this ...

  3. Depth-first search and Breadth-first search 深度优先搜索和广度优先搜索

    Depth-first search Depth-first search (DFS) is an algorithm for traversing or searching tree or grap ...

  4. 【Python排序搜索基本算法】之深度优先搜索、广度优先搜索、拓扑排序、强联通&Kosaraju算法

    Graph Search and Connectivity Generic Graph Search Goals 1. find everything findable 2. don't explor ...

  5. DFS或BFS(深度优先搜索或广度优先搜索遍历无向图)-04-无向图-岛屿数量

    给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 1: 输入: ...

  6. 深度优先搜索DFS和广度优先搜索BFS简单解析(新手向)

    深度优先搜索DFS和广度优先搜索BFS简单解析 与树的遍历类似,图的遍历要求从某一点出发,每个点仅被访问一次,这个过程就是图的遍历.图的遍历常用的有深度优先搜索和广度优先搜索,这两者对于有向图和无向图 ...

  7. 深度优先搜索(DFS)和广度优先搜索(BFS)

    深度优先搜索(DFS) 广度优先搜索(BFS) 1.介绍 广度优先搜索(BFS)是图的另一种遍历方式,与DFS相对,是以广度优先进行搜索.简言之就是先访问图的顶点,然后广度优先访问其邻接点,然后再依次 ...

  8. 深度优先搜索DFS和广度优先搜索BFS简单解析

    转自:https://www.cnblogs.com/FZfangzheng/p/8529132.html 深度优先搜索DFS和广度优先搜索BFS简单解析 与树的遍历类似,图的遍历要求从某一点出发,每 ...

  9. 利用广度优先搜索(BFS)与深度优先搜索(DFS)实现岛屿个数的问题(java)

    需要说明一点,要成功运行本贴代码,需要重新复制我第一篇随笔<简单的循环队列>代码(版本有更新). 进入今天的主题. 今天这篇文章主要探讨广度优先搜索(BFS)结合队列和深度优先搜索(DFS ...

随机推荐

  1. linux系统中的DNS服务器介绍

    http://lq2419.blog.51cto.com/1365130/1172269 DNS:Domain Name Service,linux上的DNS服务是基于一种软件BIND实现的.BIND ...

  2. filter中的dispatcher解析

    两种include方式 我自己写了一个original.jsp,另外有一个includedPage.jsp,我想在original.jsp中把includedPage.jsp引进来有两种方式: 1.& ...

  3. Map 和 WeakMap 数据结构

    Map 和 WeakMap 是ES6 新增的数据结构 一.Map 它们本质与对象一样,都是键值对的集合,但是他们与 Object 对象主要的不同是,键可以是各种类型的数值,而Object 对象的键 只 ...

  4. mysql 简单介绍

    mysql 不允许修改数据库名,一些客户端可以变通的方式来修改数据库名称 mysql 1064错误,语法错误 更改表名: rename table jian to song; 删除表 drop tab ...

  5. css实现图片水平垂直居中

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. Linux命令-压缩解压命令:gzip、gunzip

    gzip [选项] 源文件名(压缩前) gunzip [选项] 源文件名(压缩后) cd /tmp 切换tmp目录 rm -rf * 强制删除tmp目录下面所有的文件和目录 touch beijing ...

  7. 随笔小问题(一)--mac打开class文件

    本来不想写这个东西的.但是这个却费了我一番周折. 我要先声明一点的是,我从来不讲iOS当成一个单独的系统,而是将这个操作系统归位unix内核的系统. 简单来说,我把它当成linux在用. 但是,mac ...

  8. Redis全方位讲解--主从复制(转载)

    前言 前面介绍了redis持久化和容灾备份,这篇会介绍redis主从复制和redis持久化在主从复制中的一些应用.因为本人没有那么多服务器或机器,所以这里主要介绍下如何在docker容器中搭建主从复制 ...

  9. STL中map错误用法一例

    [GBK]0G's fans( me ) 13:34:26typedef struct _TX_DATA{ int len; unsigned char buff[0x100]; } TX_DATA, ...

  10. mysql分区 详解

    第18章:分区 目录 18.1. MySQL中的分区概述 18.2. 分区类型 18.2.1. RANGE分区 18.2.2. LIST分区 18.2.3. HASH分区 18.2.4. KEY分区 ...