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));
}
}
}