其他分享
首页 > 其他分享> > 认识图,用矩阵表示图

认识图,用矩阵表示图

作者:互联网

 

 

 

package graph;
//图,用二维数组(邻接矩阵)表示图
//本数组显示为红色,用的是打印System.err.println();
import java.util.ArrayList;
import java.util.Arrays;


public class Graph {
	private ArrayList<String> vertexList;//存储顶点(名字)集合
	private int[][] edges;//存储图对应的矩阵
	private int numOfEdges;//表示边的数目
	public static void main(String[] args) {
		//测试
		int n = 5;//节点个数
		String Vertexs[] = {"A","B","C","D","E","F"};
		Graph graph = new Graph(n);
		//循环添加顶点
		for(String vertex : Vertexs) {
			graph.insertVertex(vertex);
		}
		//添加边
		//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);
		graph.showGraph();
	}
	//构造器
	public Graph(int n) {
		//初始化矩阵和vertexList
		edges = new int[n][n];
		vertexList = new ArrayList<String>();
	}
	//添加顶点(名字)
	public void insertVertex(String vertex) {
		vertexList.add(vertex);	
	}
	//添加边  v1表示一个顶点,v2表示一个顶点,v1,v2用数组下标表示,weight表示两者是否相连,
    //这里设置为1.
	public void insertEdge(int v1,int v2,int weight) {
		edges[v1][v2] = weight;
		edges[v2][v1] = weight;
	}
	//图中常用方法
	//返回节点个数
	public int getNumOfVertex() {
		return vertexList.size();
	}
	//得到边的数目
	public int getNumOfEdges() {
		return numOfEdges;
	}
	//返回节点i(下标)对应的数据
	public String getValueByIndex(int i) {
		return vertexList.get(i);
	}
	//返回v1和v2的权值
	public int getWeight(int v1,int v2) {
		return edges[v1][v2];
	}
	//显示图的邻接矩阵
	public void showGraph() {
		for(int[] link : edges) {
			System.err.println(Arrays.toString(link));
		}
	}
	
}

 

标签:表示,v1,认识,graph,矩阵,int,v2,public,insertEdge
来源: https://blog.csdn.net/weixin_57711380/article/details/122161677