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

gr.james.simplegraph.WeightedEdgeImpl Maven / Gradle / Ivy

Go to download

Simple Graph is a graph interface for Java 6 that is designed to expose a very simple API to support working with graphs

The newest version!
package gr.james.simplegraph;

import java.util.Arrays;

final class WeightedEdgeImpl implements WeightedEdge {
    private final int v;
    private final int w;
    private final double weight;

    WeightedEdgeImpl(int v, int w, double weight) {
        this.v = v;
        this.w = w;
        this.weight = weight;
    }

    @Override
    public int v() {
        return v;
    }

    @Override
    public int w() {
        return w;
    }

    @Override
    public double weight() {
        return weight;
    }

    @Override
    public WeightedEdge swap() {
        WeightedEdge e = new WeightedEdgeImpl(w, v, weight);
        assert this.equals(e);
        return e;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (obj == null || !(obj instanceof WeightedEdge)) {
            return false;
        }
        final WeightedEdge that = (WeightedEdge) obj;
        return Math.min(v(), w()) == Math.min(that.v(), that.w()) &&
                Math.max(v(), w()) == Math.max(that.v(), that.w()) &&
                weight() == that.weight();
    }

    @Override
    public int hashCode() {
        return Arrays.hashCode(new Object[]{
                Math.min(v(), w()),
                Math.max(v(), w()),
                weight()});
    }

    @Override
    public String toString() {
        return String.format("%d -- %d [%.2f]", v(), w(), weight());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy