Interface MutableNetwork<N,​E>

    • Method Detail

      • addNode

        @CanIgnoreReturnValue
        boolean addNode​(N node)
        Adds node if it is not already present.

        Nodes must be unique, just as Map keys must be. They must also be non-null.

        Returns:
        true if the network was modified as a result of this call
      • addEdge

        @CanIgnoreReturnValue
        boolean addEdge​(N nodeU,
                        N nodeV,
                        E edge)
        Adds edge connecting nodeU to nodeV.

        If the graph is directed, edge will be directed in this graph; otherwise, it will be undirected.

        edge must be unique to this graph, just as a Map key must be. It must also be non-null.

        If nodeU and nodeV are not already present in this graph, this method will silently add nodeU and nodeV to the graph.

        If edge already connects nodeU to nodeV (in the specified order if this network Network.isDirected(), else in any order), then this method will have no effect.

        Returns:
        true if the network was modified as a result of this call
        Throws:
        java.lang.IllegalArgumentException - if edge already exists in the graph and does not connect nodeU to nodeV
        java.lang.IllegalArgumentException - if the introduction of the edge would violate Network.allowsParallelEdges() or Network.allowsSelfLoops()
      • addEdge

        @CanIgnoreReturnValue
        boolean addEdge​(EndpointPair<N> endpoints,
                        E edge)
        Adds edge connecting endpoints. In an undirected network, edge will also connect nodeV to nodeU.

        If this graph is directed, edge will be directed in this graph; if it is undirected, edge will be undirected in this graph.

        If this graph is directed, endpoints must be ordered.

        edge must be unique to this graph, just as a Map key must be. It must also be non-null.

        If either or both endpoints are not already present in this graph, this method will silently add each missing endpoint to the graph.

        If edge already connects an endpoint pair equal to endpoints, then this method will have no effect.

        Returns:
        true if the network was modified as a result of this call
        Throws:
        java.lang.IllegalArgumentException - if edge already exists in the graph and connects some other endpoint pair that is not equal to endpoints
        java.lang.IllegalArgumentException - if the introduction of the edge would violate Network.allowsParallelEdges() or Network.allowsSelfLoops()
        java.lang.IllegalArgumentException - if the endpoints are unordered and the graph is directed
        Since:
        27.1
      • removeNode

        @CanIgnoreReturnValue
        boolean removeNode​(N node)
        Removes node if it is present; all edges incident to node will also be removed.
        Returns:
        true if the network was modified as a result of this call
      • removeEdge

        @CanIgnoreReturnValue
        boolean removeEdge​(E edge)
        Removes edge from this network, if it is present.
        Returns:
        true if the network was modified as a result of this call