package com.atguigu.graph;
import java.util.ArrayList;
import java.util.Arrays;
/**
* ClassName: <br/>
* Description: <br/>
* Date: 2021-03-04 10:36 <br/>
* @project data_algorithm
* @package com.atguigu.graph
*/
public class Graph {
private ArrayList<String> vertexList; // 存储定点集合
private int[][] edges; // 存储图对应的临界矩阵
private int numOfEdges; // 表示变的数目
public static void main(String[] args) {
// 测试一把图是否有创建ok
int n = 5;// 节点的个数
String vertexValue[] = {"A", "B", "C", "D", "E"};
// 创建图对象
Graph graph = new Graph(n);
// 循环添加顶点
for (String value : vertexValue) {
graph.insertVertex(value);
}
// 添加边
graph.insertEdge(0,1,1);// A-B
graph.insertEdge(0,2,1); // A-C
graph.insertEdge(1,2,1); // B-C
graph.insertEdge(1,3,1); // B-D
graph.insertEdge(1,4,1); // B-E
graph.showGraph();
}
// 构造
public Graph(int n) {
// 初始化 矩阵和 vertexList
edges = new int[n][n];
vertexList = new ArrayList<String>();
numOfEdges = 0;
}
// 图中常用的方法
// 返回节点中的个数
public int getNumOfVertex() {
return vertexList.size();
}
// 显示图对应的矩阵
public void showGraph() {
for (int[] link : edges) {
System.out.println(Arrays.toString(link));
}
}
// 得到边的个数
public int getNumOfEdges() {
return numOfEdges;
}
// 返回节点i(下标)对应的数据 0->"A" 1->B 2->C
public String getValueByIndex(int i) {
return vertexList.get(i);
}
// 返回v1和v2的权值
public int getWeight(int v1, int v2) {
return edges[v1][v2];
}
/**
* 插入节点
* @param vertex
*/
public void insertVertex(String vertex) {
vertexList.add(vertex);
}
/**
* 添加边
* @param v1 表示点的下标 即 是第几个顶点 "A"="B" "A"->0 "B" ->1
* @param v2 表示第二个顶点的下标
* @param weight 表示他们是用什么关联的 是0还是1
*/
public void insertEdge(int v1, int v2, int weight) {
edges[v1][v2] = weight;
edges[v2][v1] = weight;
}
}
运行结果
[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]
Process finished with exit code 0