手动简单实现数据结构图的存储方式之邻接矩阵

邻接矩阵(Adjacency Matrix)

用两个数组来表示图。一个一维数组存储顶点,一个二维数组存储边或者弧。

Java实现

package Graph;

import java.util.ArrayList;
import java.util.List;

public class AdjacencyMatrix<T> {
    private List vertex;
    private int[][] edges;
    private int curEdges;	//当前的边数

    AdjacencyMatrix(int n){
        vertex = new ArrayList(n);
        edges = new int[n][n];
        curEdges = 0;
    }

	//顶点、边以、顶点的值以及权值的get方法
    public int getCurVertexes() {
        return vertex.size();
    }
	
    public int getCurEdges() {
        return curEdges;
    }

    public Object getVertexValue(int index){
        return vertex.get(index);
    }

    public int getWeight(int vi, int vj){
        return edges[vi][vj];
    }

	// 插入顶点
    public void insertVertex(Object v){
        vertex.add(vertex.size(), v);
    }

	//插入边
    public void insertEdge(int vi, int vj, int weight){
        edges[vi][vj] = weight;
        curEdges ++;
    }

	//删除顶点
    public void deleteVertex(int vi, int vj){
        edges[vi][vj] = 0;
        curEdges --;
    }

	//获取顶点的第一个相邻接点
    public int getFirstNeighbor(int index){
        for(int i = 0; i < vertex.size(); i++){
            if(edges[index][i] > 0)
                return i;
        }
        return -1;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值