基于java的图的实现

本文介绍了一种基于邻接表实现的图结构编码方法,并通过具体示例演示了如何使用Java进行编码实现,包括添加顶点、边及修改权重等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据结构(java)版今天看到了图那一章,也按着其大体思路编码。发现作者很多地方实现的很巧妙。

 

类图如下:


 

 

图的表示是基于邻接表实现。

 

EGraph中的vInfos存有当前图中所有的顶点。verMap为 T - Integer键值对,vertextCache为已删除节点的索引栈,但节点删除后只并没有将其从vInfos中移走,只是将其occupied属性值为false,同时将其从verMap中移走,将其索引压入栈中以便插入新节点是使用。


 VertexInfo为储存顶点信息,vertext储存顶点值,edgeList储存以该顶点为起始点的所有边信息。

Edge 为边信息,dest为该边中点在vInfos中的位置,weight为该边的权值。

 

 

 

  

 以下为针对这个图的测试

graph1.dat

 

5

A B C D E

6

A B 3

A C 2

B C 6

C B 4

C D 1

E B 5

 

package com.woxiaoe.ds.graph;

import java.io.File;
import java.util.Scanner;

import junit.framework.TestCase;

public class GraphTest extends TestCase {
	EGraph<String> graph = new EGraph<String>();
	@Override
	protected void setUp() throws Exception {
		Scanner scn = new Scanner(new File("graph1.dat"));

		int vertexNum,edgeNum;
		vertexNum = scn.nextInt();
		for(int i = 0 ; i < vertexNum; i++){
			graph.addVertex(scn.next());
		}
		edgeNum = scn.nextInt();
		for(int i = 0; i < edgeNum; i++){
			graph.addEdge(scn.next(), scn.next(), scn.nextInt());
		}
	}
	public void testReadGraph(){
		System.out.println("边数:" + graph.numberOfEdges());
		System.out.println("顶点数" + graph.numberOfVertices());
		System.out.println("C - D 权值 :" + graph.getWeight("C", "D"));
		graph.setWeight("C", "D", 10);
		System.out.println("更改后的 - D 权值 :" + graph.getWeight("C", "D"));
		System.out.println("删除C - D" + graph.removeEdge("C", "D"));
		System.out.println("删除C-D后边数:" + graph.numberOfEdges());
		System.out.println("删除C-D后顶点数:" + graph.numberOfVertices());
		System.out.println("删除顶点C:" + graph.removeVertex("C"));
		System.out.println("删除顶点C后边数:" + graph.numberOfEdges());
		System.out.println("删除顶点C后顶点数:" + graph.numberOfVertices());
		
	} 

}
 

Output:

边数:6 顶点数5 C - D 权值 :1 更改后的 - D 权值 :10 删除C - Dtrue 删除C-D后边数:5 删除C-D后顶点数:5 删除顶点C:true 删除顶点C后边数:2 删除顶点C后顶点数:4

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值