Course Schedule
                                
                                
                                    
                                
                                
                                    
                                        To solve this coding challenge, we need to determine whether it is possible to finish all given courses based on the prerequisites. This problem essentially boils down to detecting a cycle in a directed graph. If the graph contains a cycle, you cannot complete all courses, as some courses would be dependent on each other in a circular way.
                                    
                                
                                
                            
                                
                                    
                                
                                
                                    
                                        
                                
                        
                    
                    
                
                    
                Step-by-Step Explanation
- Create an Adjacency List :
- Cycle Detection Using DFS :
- Unvisited (0)
- Visiting (-1)
- Visited (1)
- Iterate Through Each Node :
- 
                                            
                                                
                                
                                
                                    
                                        Convert the list of prerequisite pairs into an adjacency list that represents the graph. Each course will point to the courses that depend on it.
                                    
                                
                                
                            
                                            
                                        
- 
                                            
                                                
                                
                                
                                    
                                        
                                            
                                
                                
                                    
                                        
                                            
                                                
                                
                                
                                    
                                        Utilize Depth-First Search (DFS) to detect cycles in the graph. If a cycle is detected, return 
                                    
                                
                                
                            
                                            
                                                
                                
                                
                                    
                                        
                                        
                                        
                                        
                                        
                                        
false
                                            
                                        - 
                                            
                                                
                                
                                
                                    
                                        
                                            
                                
                                
                                    
                                        
                                            
                                                
                                
                                
                                    
                                        Traverse each course and apply DFS to detect cycles. If no cycles are found in any part of the graph, return 
                                    
                                
                                
                            
                                            
                                                
                                
                                
                                    
                                        
                                        
                                        
                                        
                                        
                                        
true
                                            
                                        Detailed Steps in Pseudocode
Creating the Adjacency List
- Initialize : an adjacency list to an empty list for each course.
- Populate : the adjacency list with the prerequisites information.
                                            
# Initialize an empty adjacency list 
function createAdjacencyList(totalCourses, prerequisites):
    adjacencyList = list of empty lists of length totalCourses
    
    # Fill adjacency list
    for each (course, prerequisite) in prerequisites:
        append course to the list at index prerequisite in adjacencyList
    
    return adjacencyList
                                        
                                    
                                
                                
                            
                                
                                    
                                
                                
                                    
                                        DFS Function for Cycle Detection
- Base Case : If a node is being visited (visiting state -1), a cycle is detected.
- DFS : Recursively visit all the adjacent nodes.
                                            
# DFS function for detecting cycles
function isCyclic(course, adjacencyList, visitStatus):
    # If the course is in visiting state, cycle detected
    if visitStatus[course] == -1:
        return True
    
    # If the course is already visited once, no need to check again
    if visitStatus[course] == 1:
        return False
    
    # Mark the course as visiting
    visitStatus[course] = -1
    
    # Recursively visit all the adjacent courses
    for adjacentCourse in adjacencyList[course]:
        if isCyclic(adjacentCourse, adjacencyList, visitStatus):
            return True
    
    # Mark the course as visited
    visitStatus[course] = 1
    return False
                                        
                                    
                                
                                
                            
                                
                                    
                                
                                
                                    
                                        Main Function
- Initialize : List to keep track of visit states.
- Iterate : Over all courses and apply the DFS function.
                                            
# Main function that uses DFS to check all nodes
function canFinish(totalCourses, prerequisites):
    # Create the adjacency list for given courses
    adjacencyList = createAdjacencyList(totalCourses, prerequisites)
    
    # Initialize the visit status list
    visitStatus = list of zeros of length totalCourses
    
    # Check for cycles in each course
    for course from 0 to totalCourses - 1:
        if isCyclic(course, adjacencyList, visitStatus):
            return False
    
    return True
                                        
                                    
                                
                                
                            
                                
                                    
                                
                                
                                    
                                        Explanation
- Adjacency List : This method structures the prerequisites into a more accessible format for graph traversal, where each course is a node, and each prerequisite is a directed edge.
- DFS & Cycle Detection : Through Depth-First Search, we can explore each course and its dependencies. By marking nodes with visiting status, we detect cycles if we revisit a course marked as in-progress (-1).
- Final Verification : If DFS does not find a cycle for any course, it confirms that all courses can be completed.