数据结构之图(上)


图的用处也很广。搜索引擎的爬虫机器人在网上下载网页肯定用到了图这种数据结构,包括图的深度优先/广度优先算法,以及图中两个节点间的最短距离及

最短路径(路线)。本实现简单实现了图的这三个算法。


我这里用来表示图的数据结构包括节点和边(有向图,边含有权重)。


节点的实现如下:


public class Node {
     private String name;
     private boolean isVisited=false;  //是否访问过
     private boolean dis_centern=false;  //到指定节点的最短距离是否已经确定
     private int dis=0;                 //到指定点的最短距离
     private String path="";  //存储指定点到该点的路径
     
     
     
     public Node() {
	}

	public Node(String name) {
		this.name = name;
	}
	
	

	public boolean isDis_centern() {
		return dis_centern;
	}

	public void setDis_centern(boolean dis_centern) {
		this.dis_centern = dis_centern;
	}

	public int getDis() {
		return dis;
	}

	public void setDis(int dis) {
		this.dis = dis;
	}

	public String getPath() {
		return path;
	}

	public void setPath(String path) {
		this.path = path;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public boolean isVisited() {
		return isVisited;
	}

	public void setVisited(boolean isVisited) {
		this.isVisited = isVisited;
	}
	
}

边的实现如下:


   

public class Side {
    private Node from;  //边的出发节点
    private Node to;   //边的目的地节点
    private int dis;  //边的长度(权重)
    
    
	public Side(Node from, Node to, int dis) {
		this.from = from;
		this.to = to;
		this.dis = dis;
	}
	
	public Node getFrom() {
		return from;
	}


	public void setFrom(Node from) {
		this.from = from;
	}


	public Node getTo() {
		return to;
	}


	public void setTo(Node to) {
		this.to = to;
	}


	public int getDis() {
		return dis;
	}


	public void setDis(int dis) {
		this.dis = dis;
	}
	
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值