换个方式存储图结构,完美解决图的各项算法!

       在面对图的算法例如遍历、拓扑排序,最短路径时,我们常常会觉得非常麻烦,不过算法本身并不算难,难的是它的存储方式。一般来说,常用的图的存储方式有邻接矩阵和邻接表两种,那么如果我们只掌握了邻接矩阵存储时的各算法,在面对给出的邻接表结构时就会变得难以下手,反之亦然,因此来分享一种很全面的图类,能够很好的解决问题,思路来源于左程云左神


  首先我们来看图的结构,无论是有向图还是无向图,都由边集和点集构成,代码如下👇:

public class Graph {
	public HashMap<Integer, Node> nodes;
	public HashSet<Edge> edges;
	
	public Graph()
	{
		nodes = new HashMap<Integer, Node>();
        //nodes的哈希表结构中,key是节点编号,Node是节点本身
		edges = new HashSet<Edge>();
	}
}

  再来看边和点的定义分别是怎样的,边的定义如下👇:

public class Edge {
	public int weight;  //权重
	public Node from;
	public Node to;
	
	public Edge(int weight, Node from, Node to) {
		this.weight = weight;
		this.from = from;
		this.to = to;
	}
}

  点的定义如下👇:

public class Node {
	public int value;
	public int in;    //入度
	public int out;   //出度
	public ArrayList<Node> nexts;  //相邻点集
	public ArrayList<Edge> edges;  //以它为出发点的边集
	
	public Node(int val)
	{
		this.value = val;
		this.in = 0;
		this.out = 0;
		nexts = new ArrayList<Node>();
		edges = new ArrayList<Edge>();
	}
}

  将图以这样的方式表达之后,再需要写图的算法就会相对简单,在面对不同存储条件下的图结构时,可以将其自己转化为以上图的结构,这样准备好的算法代码皆能够在一个转换接口的帮助下应用于任何场合。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值