Introduction to Algorithms
3rd Edition
ISBN: 9780262033848
Author: Thomas H. Cormen, Ronald L. Rivest, Charles E. Leiserson, Clifford Stein
Publisher: MIT Press
expand_more
expand_more
format_list_bulleted
Question
Chapter 22.1, Problem 5E
Program Plan Intro
To describe the
Expert Solution & Answer
Want to see the full answer?
Check out a sample textbook solutionStudents have asked these similar questions
Consider a weighted, directed graph G with n vertices and m edges that have
integer weights. A graph walk is a sequence of not-necessarily-distinct vertices v1,
v2, ... , Vk such that each pair of consecutive vertices Vi, Vi+1 are connected by an
edge. This is similar to a path, except a walk can have repeated vertices and edges.
The length of a walk in a weighted graph is the sum of the weights of the edges in
the walk. Let s, t be given vertices in the graph, and L be a positive integer. We are
interested counting the number of walks from s to t of length exactly L.
Assume all the edge weights are positive. Describe an algorithm that computes
the number of graph walks from s to t of length exactly L in O((n+ m)L) time. Prove
the correctness and analyze the running time. (Hint: Dynamic Programming
solution)
The Triangle Vertex Deletion problem is defined as follows: Given: an undirected graph G = (V, E) , with IVI=n, and an integer k>= 0. Is there a set of at most k vertices in G whose deletion results in deleting all triangles in G? (a) Give a simple recursive backtracking algorithm that runs in O(3^k * ( p(n))) where p(n) is a low-degree polynomial corresponding to the time needed to determine whether a certain vertex belongs to a triangle in G.
(b) Selecting a vertex that belong to two different triangles can result in a better algorithm. Using this idea, provide an improved algorithm whose running time is O((2.562^n) * p(n)) where 2.652 is the positive root of the equation x^2=x+4
The transpose of a directed graph G = (V, E) is the graph GT = (V; ET), where ET = { (u, v) | (v, u) ϵ E}. Thus, GT is G with all its edges reversed. Describe efficient algorithms for computing GT from G, for both the adjacency-list and adjacency-matrix representations of G. Analyze the running times of your algorithms.
Chapter 22 Solutions
Introduction to Algorithms
Ch. 22.1 - Prob. 1ECh. 22.1 - Prob. 2ECh. 22.1 - Prob. 3ECh. 22.1 - Prob. 4ECh. 22.1 - Prob. 5ECh. 22.1 - Prob. 6ECh. 22.1 - Prob. 7ECh. 22.1 - Prob. 8ECh. 22.2 - Prob. 1ECh. 22.2 - Prob. 2E
Ch. 22.2 - Prob. 3ECh. 22.2 - Prob. 4ECh. 22.2 - Prob. 5ECh. 22.2 - Prob. 6ECh. 22.2 - Prob. 7ECh. 22.2 - Prob. 8ECh. 22.2 - Prob. 9ECh. 22.3 - Prob. 1ECh. 22.3 - Prob. 2ECh. 22.3 - Prob. 3ECh. 22.3 - Prob. 4ECh. 22.3 - Prob. 5ECh. 22.3 - Prob. 6ECh. 22.3 - Prob. 7ECh. 22.3 - Prob. 8ECh. 22.3 - Prob. 9ECh. 22.3 - Prob. 10ECh. 22.3 - Prob. 11ECh. 22.3 - Prob. 12ECh. 22.3 - Prob. 13ECh. 22.4 - Prob. 1ECh. 22.4 - Prob. 2ECh. 22.4 - Prob. 3ECh. 22.4 - Prob. 4ECh. 22.4 - Prob. 5ECh. 22.5 - Prob. 1ECh. 22.5 - Prob. 2ECh. 22.5 - Prob. 3ECh. 22.5 - Prob. 4ECh. 22.5 - Prob. 5ECh. 22.5 - Prob. 6ECh. 22.5 - Prob. 7ECh. 22 - Prob. 1PCh. 22 - Prob. 2PCh. 22 - Prob. 3PCh. 22 - Prob. 4P
Knowledge Booster
Similar questions
- Please help me with this practice problem in python : Implement two-level iterative method B = B_{TL} for graph Laplacian matrices. We want the symmetric B. Components: Given a graph, construct its graph Laplacian matrix. Then using Luby's algorithm, construct the P matrix that ensures a prescribed coarsening factor, e.g., 2, 4, or 8 times smaller number of coarse vertices. Since the graph Laplacian matrix is singular (it has the constants in its nullspace), to make it invertible, make its last row and columns zero, but keep the diagonal as it were (nonzero). The resulting modified graph Laplacian matrix A is invertible and s.p.d.. Form the coarse matrix A_c = P^TAP. To implement symmetric two-level cycle use one of the following M and M^T: (i) M is forward Gauss-Seidel, M^T - backward Gauss-Seidel (both corresponding to A) (ii) M = M^T - the ell_1 smoother. Compare the performance (convergence properties in terms of number of iterations) of B w.r.t. just using the smoother M…arrow_forwardConsider the Minimum-Weight-Cycle Problem: Input: A directed weighted graph G (V, E) (where the weight of edge e is w(e)) and an integer k. Output: TRUE if there is a cycle with total weight at most k and FALSE if there is no cycle with total weight at most k. Remember, a cycle is a list of vertices such that each vertex has an edge to the next and the final vertex has an edge to the first vertex. Each vertex can only occur once in the cycle. A vertex with a self-loop forms a cycle by itself. (a) Assume that all edge weights are positive. Give a polynomial-time algorithm for the Minimum-Weight-Cycle Problem. For full credit, you should: - Give a clear description of your algorithm. If you give pseudocode, you should support it with an expla- nation of what the algorithm does. Give the running time of your algorithm in terms of the number of vertices n and the number of edges m. You do not need to prove the correctness of your algorithm or the correctness of your running time analysis.arrow_forwardWe recollect that Kruskal's Algorithm is used to find the minimum spanning tree in a weighted graph. Given a weighted undirected graph G = (V , E, W), with n vertices/nodes, the algorithm will first sort the edges in E according to their weights. It will then select (n-1) edges with smallest weights that do not form a cycle. (A cycle in a graph is a path along the edges of a graph that starts at a node and ends at the same node after visiting at least one other node and not traversing any of the edges more than once.) Use Kruskal's Algorithm to nd the weight of the minimum spanning tree for the following graph.arrow_forward
- Let G be a directed acyclic graph. You would like to know if graph G contains directed path that goes through every vertex exactly once. Give an algorithm that tests this property. Provide justification of the correctness and analyze running time complexity of your algorithm. Your algorithm must have a running time in O(|V | + |E|). Detailed pseudocode is required.arrow_forwardLet G be a graph with V vertices and E edges. One can implement Kruskal’s Algorithm to run in O(E log V) time, and Prim’s Algorithm to run in O(E + V log V ) time. If G is a dense graph with an extremely large number of vertices, determine which algorithm would output the minimum-weight spanning tree more quickly. Clearly justify your answer.arrow_forwardThe reverse of a directed graph G = (V,E) is another directed graph G^R = (V,E^R) on the same vertex set, but with all edges reversed; that is, E^R = {(v, u) : (u, v) ∈ E}.Give a linear-time algorithm for computing the reverse of a graph in adjacency list format.arrow_forward
- Most graph algorithms that take an n×n adjacency-matrix representation as input require at least time O(n^2), but there are some exceptions. Show how to determine whether a simple directed graph G contains a universal sink, that is, a vertex with in degree n − 1 and out-degree 0, in time O(n) given an n × n adjacency matrix for G. (A vertex v has indegree k if there are precisely k edges of the form (u, v), and has outdegree k if there are precisely k edges of the form (v, u).)arrow_forwardConsider the Minimum-Weight-Cycle Problem: Input: A directed weighted graph G = :(V, E) (where the weight of edge e is w(e)) and an integer k. Output: TRUE if there is a cycle with total weight at most k and FALSE if there is no cycle with total weight at most k. Remember, a cycle is a list of vertices such that each vertex has an edge to the next and the final vertex has an edge to the first vertex. Each vertex can only occur once in the cycle. A vertex with a self-loop forms a cycle by itself. (a) Assume that all edge weights are positive. Give a polynomial-time algorithm for the Minimum-Weight-Cycle Problem. For full credit, you should: Give a clear description of your algorithm. If you give pseudocode, you should support it with an expla- nation of what the algorithm does. Give the running time of your algorithm in terms of the number of vertices n and the number of edges m. - You do not need to prove the correctness of your algorithm or the correctness of your running time…arrow_forwardSuppose are you given an undirected graph G = (V, E) along with three distinct designated vertices u, v, and w. Describe and analyze a polynomial time algorithm that determines whether or not there is a simple path from u to w that passes through v. [Hint: By definition, each vertex of G must appear in the path at most once.]arrow_forward
- Give a linear time algorithm via pseudo code that takes as input a directed acyclic graph G (V, E) and two vertices u and v, that returns the number of simple paths from u to v in G. Your algorithm needs only to count the simple paths, not list them. Explain why your code runs in linear time.arrow_forwardWe are given a graph G = (V, E); G could be a directed graph or undirected graph. Let M bethe adjacency matrix of G. Let n be the number of vertices so that the matrix M is n ×n matrix. For anymatrix A, let us denote the element of i-th row and j-th column of the matrix A by A[i, j].1. Consider the square of the adjacency matrix M . For all i and j, show that M 2[i, j] is the number ofdifferent paths of length 2 from the i-th vertex to the j-th vertex. It should be explained or proved asclearly as possible.2. For any positive integer k, show that M k[i, j] is the number of different paths of length k from the i-th vertex to the j-th vertex. You may use induction on k to prove it.3. Assume that we are given a positive integer k. Design an algorithm to find the number of different paths of length k from the i-th vertex to j-th vertex for all pairs of (i, j). The time complexity of your algorithm should be O(n3 log k). You can get partial credits if you design an algorithm of O(n3k).arrow_forwardYou are given a bipartite graph G=(U,V,E), and an integer K. U and V are the two bipartitions of the graph such that |U| = |V| = N , and E is the edge set. The vertices of U are {1,2,...,N } and that of V are {N+1,N+2,...,2N }. You need to find out whether the total number of different perfect matchings in G is strictly greater than K or not. Recall that a perfect matching is a subset of E such that every vertex of the graph belongs to exactly one edge in the subset. Two perfect matchings are considered to be different even if one edge is different. Write a program in C++ programming language that prints a single line containing “Perfect” if the number of perfect matchings is greater than K, and “Not perfect” in other cases.Sample Input:3 5 21 42 62 53 53 5Output:Not Perfectarrow_forward
arrow_back_ios
SEE MORE QUESTIONS
arrow_forward_ios
Recommended textbooks for you
- Database System ConceptsComputer ScienceISBN:9780078022159Author:Abraham Silberschatz Professor, Henry F. Korth, S. SudarshanPublisher:McGraw-Hill EducationStarting Out with Python (4th Edition)Computer ScienceISBN:9780134444321Author:Tony GaddisPublisher:PEARSONDigital Fundamentals (11th Edition)Computer ScienceISBN:9780132737968Author:Thomas L. FloydPublisher:PEARSON
- C How to Program (8th Edition)Computer ScienceISBN:9780133976892Author:Paul J. Deitel, Harvey DeitelPublisher:PEARSONDatabase Systems: Design, Implementation, & Manag...Computer ScienceISBN:9781337627900Author:Carlos Coronel, Steven MorrisPublisher:Cengage LearningProgrammable Logic ControllersComputer ScienceISBN:9780073373843Author:Frank D. PetruzellaPublisher:McGraw-Hill Education
Database System Concepts
Computer Science
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:McGraw-Hill Education
Starting Out with Python (4th Edition)
Computer Science
ISBN:9780134444321
Author:Tony Gaddis
Publisher:PEARSON
Digital Fundamentals (11th Edition)
Computer Science
ISBN:9780132737968
Author:Thomas L. Floyd
Publisher:PEARSON
C How to Program (8th Edition)
Computer Science
ISBN:9780133976892
Author:Paul J. Deitel, Harvey Deitel
Publisher:PEARSON
Database Systems: Design, Implementation, & Manag...
Computer Science
ISBN:9781337627900
Author:Carlos Coronel, Steven Morris
Publisher:Cengage Learning
Programmable Logic Controllers
Computer Science
ISBN:9780073373843
Author:Frank D. Petruzella
Publisher:McGraw-Hill Education