Open In App

Detecting negative cycle using Floyd Warshall

Last Updated : 13 Oct, 2023
Improve
Improve
Like Article
Like
Save
Share
Report

We are given a directed graph. We need compute whether the graph has negative cycle or not. A negative cycle is one in which the overall sum of the cycle comes negative.

negative_cycle

Negative weights are found in various applications of graphs. For example, instead of paying cost for a path, we may get some advantage if we follow the path.

Examples: 

Input : 4 4
0 1 1
1 2 -1
2 3 -1
3 0 -1

Output : Yes
The graph contains a negative cycle.

Detecting negative cycle using Floyd Warshall

We have discussed Bellman Ford Algorithm based solution for this problem.
In this post, Floyd Warshall Algorithm based solution is discussed that works for both connected and disconnected graphs.
Distance of any node from itself is always zero. But in some cases, as in this example, when we traverse further from 4 to 1, the distance comes out to be -2, i.e. distance of 1 from 1 will become -2. This is our catch, we just have to check the nodes distance from itself and if it comes out to be negative, we will detect the required negative cycle.

Implementation:

C++




// C++ Program to check if there is a negative weight
// cycle using Floyd Warshall Algorithm
#include<bits/stdc++.h>
using namespace std;
 
// Number of vertices in the graph
#define V 4
  
/* Define Infinite as a large enough value. This
   value will be used for vertices not connected
   to each other */
#define INF 99999
  
// A function to print the solution matrix
void printSolution(int dist[][V]);
  
// Returns true if graph has negative weight cycle
// else false.
bool negCyclefloydWarshall(int graph[][V])
{
    /* dist[][] will be the output matrix that will
       finally have the shortest
    distances between every pair of vertices */
    int dist[V][V], i, j, k;
  
    /* Initialize the solution matrix same as input
      graph matrix. Or we can say the initial values
      of shortest distances are based on shortest
      paths considering no intermediate vertex. */
    for (i = 0; i < V; i++)
        for (j = 0; j < V; j++)
            dist[i][j] = graph[i][j];
  
    /* Add all vertices one by one to the set of
       intermediate vertices.
    ---> Before start of a iteration, we have shortest
         distances between all pairs of vertices such
         that the shortest distances consider only the
         vertices in set {0, 1, 2, .. k-1} as intermediate
         vertices.
    ----> After the end of a iteration, vertex no. k is
          added to the set of intermediate vertices and
          the set becomes {0, 1, 2, .. k} */
    for (k = 0; k < V; k++)
    {
        // Pick all vertices as source one by one
        for (i = 0; i < V; i++)
        {
            // Pick all vertices as destination for the
            // above picked source
            for (j = 0; j < V; j++)
            {
                // If vertex k is on the shortest path from
                // i to j, then update the value of dist[i][j]
                if (dist[i][k] + dist[k][j] < dist[i][j])
                        dist[i][j] = dist[i][k] + dist[k][j];
            }
        }
    }
 
    // If distance of any vertex from itself
    // becomes negative, then there is a negative
    // weight cycle.
    for (int i = 0; i < V; i++)
        if (dist[i][i] < 0)
            return true;
    return false;
}
  
 // driver program
int main()
{
    /* Let us create the following weighted graph
            1
    (0)----------->(1)
    /|\             |
     |              |
  -1 |              | -1
     |             \|/
    (3)<-----------(2)
        -1       */
         
    int graph[V][V] = { {0   , 1   , INF , INF},
                        {INF , 0   , -1  , INF},
                        {INF , INF , 0   ,  -1},
                        {-1  , INF , INF ,   0}};
     
    if (negCyclefloydWarshall(graph))
       cout << "Yes";
    else
       cout << "No";
    return 0;
}


Java




// Java Program to check if there is a negative weight
// cycle using Floyd Warshall Algorithm
class GFG
{
 
    // Number of vertices in the graph
    static final int V = 4;
     
    /* Define Infinite as a large enough value. This
    value will be used for vertices not connected
    to each other */
    static final int INF = 99999;
     
    // Returns true if graph has negative weight cycle
    // else false.
    static boolean negCyclefloydWarshall(int graph[][])
    {
         
        /* dist[][] will be the output matrix that will
        finally have the shortest
        distances between every pair of vertices */
        int dist[][] = new int[V][V], i, j, k;
     
        /* Initialize the solution matrix same as input
        graph matrix. Or we can say the initial values
        of shortest distances are based on shortest
        paths considering no intermediate vertex. */
        for (i = 0; i < V; i++)
            for (j = 0; j < V; j++)
                dist[i][j] = graph[i][j];
     
        /* Add all vertices one by one to the set of
        intermediate vertices.
        ---> Before start of a iteration, we have shortest
            distances between all pairs of vertices such
            that the shortest distances consider only the
            vertices in set {0, 1, 2, .. k-1} as intermediate
            vertices.
        ----> After the end of a iteration, vertex no. k is
            added to the set of intermediate vertices and
            the set becomes {0, 1, 2, .. k} */
        for (k = 0; k < V; k++)
        {
             
            // Pick all vertices as source one by one
            for (i = 0; i < V; i++)
            {
                 
                // Pick all vertices as destination for the
                // above picked source
                for (j = 0; j < V; j++)
                {
                     
                    // If vertex k is on the shortest path from
                    // i to j, then update the value of dist[i][j]
                    if (dist[i][k] + dist[k][j] < dist[i][j])
                            dist[i][j] = dist[i][k] + dist[k][j];
                }
            }
        }
     
        // If distance of any vertex from itself
        // becomes negative, then there is a negative
        // weight cycle.
        for (i = 0; i < V; i++)
            if (dist[i][i] < 0)
                return true;
 
        return false;
    }
         
    // Driver code
    public static void main (String[] args)
    {
     
    /* Let us create the following weighted graph
                1
        (0)----------->(1)
        /|\               |
         |               |
      -1 |               | -1
         |                \|/
        (3)<-----------(2)
            -1     */
             
        int graph[][] = { {0, 1, INF, INF},
                          {INF, 0, -1, INF},
                          {INF, INF, 0, -1},
                          {-1, INF, INF, 0}};
         
        if (negCyclefloydWarshall(graph))
            System.out.print("Yes");
        else
            System.out.print("No");
    }
}
 
// This code is contributed by Anant Agarwal.


Python3




# Python Program to check
# if there is a
# negative weight
# cycle using Floyd
# Warshall Algorithm
 
  
# Number of vertices
# in the graph
V = 4
      
# Define Infinite as a
# large enough value. This
# value will be used
#for vertices not connected
# to each other
INF = 99999
      
# Returns true if graph has
# negative weight cycle
# else false.
def negCyclefloydWarshall(graph):
          
    # dist[][] will be the
    # output matrix that will
    # finally have the shortest
    # distances between every
    # pair of vertices
    dist=[[0 for i in range(V+1)]for j in range(V+1)]
      
    # Initialize the solution
    # matrix same as input
    # graph matrix. Or we can
    # say the initial values
    # of shortest distances
    # are based on shortest
    # paths considering no
    # intermediate vertex.
    for i in range(V):
        for j in range(V):
            dist[i][j] = graph[i][j]
      
    ''' Add all vertices one
        by one to the set of
        intermediate vertices.
    ---> Before start of a iteration,
         we have shortest
        distances between all pairs
        of vertices such
        that the shortest distances
        consider only the
        vertices in set {0, 1, 2, .. k-1}
        as intermediate vertices.
    ----> After the end of a iteration,
          vertex no. k is
        added to the set of
        intermediate vertices and
        the set becomes {0, 1, 2, .. k} '''
    for k in range(V):
     
        # Pick all vertices
        # as source one by one
        for i in range(V):
                  
            # Pick all vertices as
            # destination for the
            # above picked source
            for j in range(V):
         
                # If vertex k is on
                # the shortest path from
                # i to j, then update
                # the value of dist[i][j]
                if (dist[i][k] + dist[k][j] < dist[i][j]):
                        dist[i][j] = dist[i][k] + dist[k][j]
  
    # If distance of any
    # vertex from itself
    # becomes negative, then
    # there is a negative
    # weight cycle.
    for i in range(V):
        if (dist[i][i] < 0):
            return True
  
    return False
 
          
# Driver code
 
      
''' Let us create the
    following weighted graph
            1
    (0)----------->(1)
    /|\               |
     |               |
  -1 |               | -1
     |                \|/
    (3)<-----------(2)
        -1     '''
          
graph = [ [0, 1, INF, INF],
          [INF, 0, -1, INF],
          [INF, INF, 0, -1],
          [-1, INF, INF, 0]]
          
if (negCyclefloydWarshall(graph)):
    print("Yes")
else:
    print("No")
 
# This code is contributed
# by Anant Agarwal.


C#




// C# Program to check if there
// is a negative weight cycle
// using Floyd Warshall Algorithm
 
using System;
 
namespace Cycle
{
public class GFG
{    
     
 
    // Number of vertices in the graph
    static int V = 4;
     
    /* Define Infinite as a large enough value. This
    value will be used for vertices not connected
    to each other */
    static int INF = 99999;
     
    // Returns true if graph has negative weight cycle
    // else false.
    static bool negCyclefloydWarshall(int [,]graph)
    {
         
        /* dist[][] will be the output matrix that will
        finally have the shortest
        distances between every pair of vertices */
        int [,]dist = new int[V,V];
        int i, j, k;
     
        /* Initialize the solution matrix same as input
        graph matrix. Or we can say the initial values
        of shortest distances are based on shortest
        paths considering no intermediate vertex. */
        for (i = 0; i < V; i++)
            for (j = 0; j < V; j++)
                dist[i,j] = graph[i,j];
     
        /* Add all vertices one by one to the set of
        intermediate vertices.
        ---> Before start of a iteration, we have shortest
            distances between all pairs of vertices such
            that the shortest distances consider only the
            vertices in set {0, 1, 2, .. k-1} as intermediate
            vertices.
        ----> After the end of a iteration, vertex no. k is
            added to the set of intermediate vertices and
            the set becomes {0, 1, 2, .. k} */
        for (k = 0; k < V; k++)
        {
             
            // Pick all vertices as source one by one
            for (i = 0; i < V; i++)
            {
                 
                // Pick all vertices as destination for the
                // above picked source
                for (j = 0; j < V; j++)
                {
                     
                    // If vertex k is on the shortest path from
                    // i to j, then update the value of dist[i][j]
                    if (dist[i,k] + dist[k,j] < dist[i,j])
                            dist[i,j] = dist[i,k] + dist[k,j];
                }
            }
        }
     
        // If distance of any vertex from itself
        // becomes negative, then there is a negative
        // weight cycle.
        for (i = 0; i < V; i++)
            if (dist[i,i] < 0)
                return true;
 
        return false;
    }
         
    // Driver code
    public static void Main()
    {
     
    /* Let us create the following weighted graph
                1
        (0)----------->(1)
        /|\             |
        |             |
    -1 |             | -1
        |             \|/
        (3)<-----------(2)
            -1     */
             
        int [,]graph = { {0, 1, INF, INF},
                        {INF, 0, -1, INF},
                        {INF, INF, 0, -1},
                        {-1, INF, INF, 0}};
         
        if (negCyclefloydWarshall(graph))
            Console.Write("Yes");
        else
            Console.Write("No");
    }
}
}
 
// This code is contributed by Sam007.


Javascript




<script>
 
// JavaScript Program to check if there
// is a negative weight cycle
// using Floyd Warshall Algorithm
// Number of vertices in the graph
var V = 4;
 
/* Define Infinite as a large enough value. This
value will be used for vertices not connected
to each other */
var INF = 99999;
 
// Returns true if graph has negative weight cycle
// else false.
function negCyclefloydWarshall(graph)
{
     
    /* dist[][] will be the output matrix that will
    finally have the shortest
    distances between every pair of vertices */
    var dist = Array.from(Array(V), ()=>Array(V));
    var i, j, k;
 
    /* Initialize the solution matrix same as input
    graph matrix. Or we can say the initial values
    of shortest distances are based on shortest
    paths considering no intermediate vertex. */
    for (i = 0; i < V; i++)
        for (j = 0; j < V; j++)
            dist[i][j] = graph[i][j];
 
    /* Add all vertices one by one to the set of
    intermediate vertices.
    ---> Before start of a iteration, we have shortest
        distances between all pairs of vertices such
        that the shortest distances consider only the
        vertices in set {0, 1, 2, .. k-1} as intermediate
        vertices.
    ----> After the end of a iteration, vertex no. k is
        added to the set of intermediate vertices and
        the set becomes {0, 1, 2, .. k} */
    for (k = 0; k < V; k++)
    {
         
        // Pick all vertices as source one by one
        for (i = 0; i < V; i++)
        {
             
            // Pick all vertices as destination for the
            // above picked source
            for (j = 0; j < V; j++)
            {
                 
                // If vertex k is on the shortest path from
                // i to j, then update the value of dist[i][j]
                if (dist[i][k] + dist[k][j] < dist[i][j])
                        dist[i][j] = dist[i][k] + dist[k][j];
            }
        }
    }
 
    // If distance of any vertex from itself
    // becomes negative, then there is a negative
    // weight cycle.
    for (i = 0; i < V; i++)
        if (dist[i][i] < 0)
            return true;
    return false;
}
     
// Driver code
 
/* Let us create the following weighted graph
            1
    (0)----------->(1)
    /|\             |
    |             |
-1 |             | -1
    |             \|/
    (3)<-----------(2)
    -1     */
     
var graph = [ [0, 1, INF, INF],
                [INF, 0, -1, INF],
                [INF, INF, 0, -1],
                [-1, INF, INF, 0]];
 
if (negCyclefloydWarshall(graph))
    document.write("Yes");
else
    document.write("No");
 
 
</script>


Output

Yes

The time complexity of the Floyd Warshall algorithm is O(V^3) where V is the number of vertices in the graph. This is because the algorithm uses a nested loop structure, where the outermost loop runs V times, the middle loop runs V times and the innermost loop also runs V times. Therefore, the total number of iterations is V * V * V which results in O(V^3) time complexity.

The space complexity of the Floyd Warshall algorithm is O(V^2) where V is the number of vertices in the graph. This is because the algorithm uses a 2D array of size V x V to store the shortest distances between every pair of vertices. Therefore, the total space required is V * V which results in O(V^2) space complexity.

 



Previous Article
Next Article

Similar Reads

Finding shortest path between any two nodes using Floyd Warshall Algorithm
Given a graph and two nodes u and v, the task is to print the shortest path between u and v using the Floyd Warshall algorithm. Examples: Input: u = 1, v = 3 Output: 1 -&gt; 2 -&gt; 3 Explanation: Shortest path from 1 to 3 is through vertex 2 with total cost 3. The first edge is 1 -&gt; 2 with cost 2 and the second edge is 2 -&gt; 3 with cost 1. In
13 min read
Transitive closure of a graph using Floyd Warshall Algorithm
Given a directed graph, determine if a vertex j is reachable from another vertex i for all vertex pairs (i, j) in the given graph. Here reachable means that there is a path from vertex i to j. The reach-ability matrix is called the transitive closure of a graph. For example, consider below graph Transitive closure of above graphs is 1 1 1 1 1 1 1 1
12 min read
Comparison of Dijkstra’s and Floyd–Warshall algorithms
Dijkstra AlgorithmDijkstra’s Algorithm is a Single-Source Shortest Path SSSP algorithm, i.e., given a source vertex it finds the shortest path from the source to all other vertices. The idea is to generate a SPT (shortest path tree) with a given source as a root and with two sets, one set contains vertices included in the shortest-path tree, other
4 min read
Bellman-Ford vs Floyd-Warshall's algorithm: A Comparative Analysis
Bellman-Ford Algorithm:The Bellman-Ford algorithm is a single-source shortest-path algorithm that works by iteratively relaxing edges in the graph until the shortest path to all vertices is found. It is especially useful for graphs with negative edge weights, as it can detect negative cycles and return a suitable error message. Floyd-Warshall Algor
15+ min read
Time and Space Complexity of Floyd Warshall Algorithm
The Floyd Warshall Algorithm has a time complexity of O(V3) and a space complexity of O(V2), where V represents the number of vertices in the graph. This algorithm computes the shortest paths between all pairs of vertices in a weighted graph. The time complexity arises from the triple nested loops used to update the shortest path matrix, while the
3 min read
Floyd Warshall Algorithm
The Floyd-Warshall algorithm, named after its creators Robert Floyd and Stephen Warshall, is a fundamental algorithm in computer science and graph theory. It is used to find the shortest paths between all pairs of nodes in a weighted graph. This algorithm is highly efficient and can handle graphs with both positive and negative edge weights, making
15+ min read
Floyd-Warshall Algorithm in Python
The Floyd-Warshall algorithm, named after its creators Robert Floyd and Stephen Warshall, is fundamental in computer science and graph theory. It is used to find the shortest paths between all pairs of nodes in a weighted graph. This algorithm is highly efficient and can handle graphs with both positive and negative edge weights, making it a versat
4 min read
Floyd’s Cycle Finding Algorithm
Floyd's cycle finding algorithm or Hare-Tortoise algorithm is a pointer algorithm that uses only two pointers, moving through the sequence at different speeds. This algorithm is used to find a loop in a linked list. It uses two pointers one moving twice as fast as the other one. The faster one is called the fast pointer and the other one is called
14 min read
Detect a negative cycle in a Graph using Shortest Path Faster Algorithm
Given a graph G consisting of nodes valued [0, N - 1], a source S, and an array Edges[][3] of type {u, v, w} that denotes that there is a directed edge between node u and v with weight w, the task is to check if there exists a negative cycle from the given source. If found to be true, then print "Yes". Otherwise, print "No". A negative cycle is a c
11 min read
Detect a negative cycle in a Graph | (Bellman Ford)
Given a directed weighted graph, the task is to find whether the given graph contains any negative-weight cycle or not. Note: A negative-weight cycle is a cycle in a graph whose edges sum to a negative value. Example: Input: Output: No Input: Output: Yes Algorithm to Find Negative Cycle in a Directed Weighted Graph Using Bellman-Ford:Initialize dis
15+ min read
Practice Tags :