Class RatioVertex<V>

  • Type Parameters:
    V - the graph vertex type
    All Implemented Interfaces:
    java.lang.Comparable<RatioVertex<V>>

    public class RatioVertex<V>
    extends java.lang.Object
    implements java.lang.Comparable<RatioVertex<V>>
    Helper class for vertex covers. Guarantees that vertices can be sorted, thereby obtaining a unique ordering.
    Author:
    Joris Kinable
    • Field Summary

      Fields 
      Modifier and Type Field Description
      protected int degree
      degree of this vertex
      int id
      unique id, used to guarantee that compareTo never returns 0
      int ID
      Deprecated, for removal: This API element is subject to removal in a future version.
      use id instead
      java.util.Map<RatioVertex<V>,​java.lang.Integer> neighbors
      Map of neighbors, and a count of the number of edges to this neighbor
      V v
      original vertex
      double weight
      weight of the vertex
    • Constructor Summary

      Constructors 
      Constructor Description
      RatioVertex​(int id, V v, double weight)
      Create a new ratio vertex
    • Field Detail

      • v

        public final V v
        original vertex
      • weight

        public double weight
        weight of the vertex
      • ID

        @Deprecated(since="1.5.2",
                    forRemoval=true)
        public final int ID
        Deprecated, for removal: This API element is subject to removal in a future version.
        use id instead
        unique id, used to guarantee that compareTo never returns 0
      • id

        public final int id
        unique id, used to guarantee that compareTo never returns 0
      • degree

        protected int degree
        degree of this vertex
      • neighbors

        public final java.util.Map<RatioVertex<V>,​java.lang.Integer> neighbors
        Map of neighbors, and a count of the number of edges to this neighbor
    • Constructor Detail

      • RatioVertex

        public RatioVertex​(int id,
                           V v,
                           double weight)
        Create a new ratio vertex
        Parameters:
        id - unique id
        v - the vertex
        weight - the vertex weight
    • Method Detail

      • addNeighbor

        public void addNeighbor​(RatioVertex<V> v)
        Add a neighbor.
        Parameters:
        v - the neighbor
      • removeNeighbor

        public void removeNeighbor​(RatioVertex<V> v)
        Remove a neighbor.
        Parameters:
        v - the neighbor to remove
      • getDegree

        public int getDegree()
        Returns the degree of the vertex
        Returns:
        degree of the vertex
      • getRatio

        public double getRatio()
        Returns the ratio between the vertex' weight and its degree
        Returns:
        the ratio between the vertex' weight and its degree
      • compareTo

        public int compareTo​(RatioVertex<V> other)
        Specified by:
        compareTo in interface java.lang.Comparable<V>
      • hashCode

        public int hashCode()
        Overrides:
        hashCode in class java.lang.Object
      • equals

        public boolean equals​(java.lang.Object o)
        Overrides:
        equals in class java.lang.Object
      • toString

        public java.lang.String toString()
        Overrides:
        toString in class java.lang.Object