gr.james.simplegraph.EdgeImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of simple-graph Show documentation
Show all versions of simple-graph Show documentation
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 EdgeImpl implements Edge {
private final int v;
private final int w;
EdgeImpl(int v, int w) {
this.v = v;
this.w = w;
}
@Override
public int v() {
return v;
}
@Override
public int w() {
return w;
}
@Override
public Edge swap() {
Edge e = new EdgeImpl(w, v);
assert this.equals(e);
return e;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null || !(obj instanceof Edge)) {
return false;
}
final Edge that = (Edge) obj;
return Math.min(v(), w()) == Math.min(that.v(), that.w()) &&
Math.max(v(), w()) == Math.max(that.v(), that.w());
}
@Override
public int hashCode() {
return Arrays.hashCode(new Object[]{
Math.min(v(), w()),
Math.max(v(), w())});
}
@Override
public String toString() {
return String.format("%d -- %d", v(), w());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy