All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jgrapht.experimental.alg.IntArrayGraphAlgorithm Maven / Gradle / Ivy

/* This program and the accompanying materials are dual-licensed under
 * either
 *
 * (a) the terms of the GNU Lesser General Public License version 2.1
 * as published by the Free Software Foundation, or (at your option) any
 * later version.
 *
 * or (per the licensee's choosing)
 *
 * (b) the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation.
 */
/**
 *
 */
package org.jgrapht.experimental.alg;

import java.util.*;

import org.jgrapht.*;


/**
 * @author micha
 */
public abstract class IntArrayGraphAlgorithm
{
    

    protected final List _vertices;
    protected final int [][] _neighbors;
    protected final Map _vertexToPos;

    

    /**
     * @param g
     */
    public IntArrayGraphAlgorithm(final Graph g)
    {
        final int numVertices = g.vertexSet().size();
        _vertices = new ArrayList(numVertices);
        _neighbors = new int[numVertices][];
        _vertexToPos = new HashMap(numVertices);
        for (V vertex : g.vertexSet()) {
            _neighbors[_vertices.size()] = new int[g.edgesOf(vertex).size()];
            _vertexToPos.put(vertex, _vertices.size());
            _vertices.add(vertex);
        }
        for (int i = 0; i < numVertices; i++) {
            int nbIndex = 0;
            final V vertex = _vertices.get(i);
            for (E e : g.edgesOf(vertex)) {
                _neighbors[i][nbIndex++] =
                    _vertexToPos.get(Graphs.getOppositeVertex(g, e, vertex));
            }
        }
    }
}

// End IntArrayGraphAlgorithm.java




© 2015 - 2024 Weber Informatics LLC | Privacy Policy