在图的遍历模式中应用设计模式

今天在写图的算法时,想到如果要实现了求一个节点相邻的节点,该怎么写:

稀疏图是邻接表实现的:


稠密图是邻接矩阵实现的:



问题:

得到g这个变量进行操作,保持g变量的私有特性,而又让外部能遍历到这个数据?

用模板方法来统一接口,这样外部调用统一的接口就可以访问这个点所有相邻点的集合了。

邻接矩阵:
// 返回图中一个顶点的所有邻边
    public Iterable<Integer> adj(int v) {
        assert v >= 0 && v < n;
        Vector<Integer> adjV = new Vector<Integer>();
        for(int i = 0 ; i < n ; i ++ )
            if( g[v][i] )
                adjV.add(i);
        return adjV;
    }
邻接表:
// 返回图中一个顶点的所有邻边
    public Iterable<Integer> adj(int v) {
        assert v >= 0 && v < n;
        return g[v];
    }

这样,在统一调用时,就无需知道内部是什么,也不需要稀疏图和稠密图分开调用了,调用统一接口就可以了:

 public static void main(String[] args) {

        // 使用两种图的存储方式读取testG1.txt文件
        String filename = "F:\\Algorithm-Base\\src\\wang\\Graph\\testG1.txt";
        SparseGraph g1 = new SparseGraph(13, false);
        ReadGraph readGraph1 = new ReadGraph(g1, filename);
        for(int i = 0; i < g1.V(); i ++){
            Iterator<Integer> iter = g1.adj(i).iterator();
            System.out.print("第" + i + "个顶点所相邻的结点:");
            while(iter.hasNext()){
                System.out.print(iter.next() + " ");
            }
            System.out.println();
        }
}

test1的数据是:

  

输出的结果:



总结: 有时候写代码时,应该多想想这个代码的整体性,是不是可以多个相同的方法可以写成一个模板,提供一个统一的接口是调用~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值