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
Concept explainers
Question
Chapter 15.1, Problem 2E
Program Plan Intro
To give a counter example so that the following greedy strategy does not always determine an optimal way to cut rods.
Expert Solution & Answer
Want to see the full answer?
Check out a sample textbook solutionStudents have asked these similar questions
Exercise 4
20= 10+4+6
The rod-cutting problem consists of a rod of n units long that can be cut into integer-length
pieces. The sale price of a piece i units long is Pi for i = 1,...,n. We want to apply dynamic
programming to find the maximum total sale price of the rod. Let F(k) be the maximum price
for a given rod of length k.
1. Give the recurrence on F(k) and its initial condition(s).
2. What are the time and space efficiencies of your algorithm?
Now, consider the following instance of the rod-cutting problem: a rod of length n=5, and the
following sale prices P1=2, P2=3, P3-7, P4=2 and P5=5.
Let's say there are n villages, {X1, . . . , Xn} on the country-road and we aim to build K < n restaurants to cover them. Each restaurant has to be built in a village, and we hope to minimize the average distance from each village to the closest restaurant. Please give an algorithm to compute the optimal way to place these K restaurants. The algorithm should run in O(k * n^2) time. Solutions with slightly higher time complexity also accepted.
An electrician has wired n lights, all initially on, so that:
1) light 1 can always be turned on/off, and
2) for k > 1, light k cannot be turned either on or off unless light k – 1 is on and all preceding lights
are off for k > 1.
The question we want to explore is the following: how many moves are required to turn all n lights
off? For n = 5, a solution sequence has been worked out below. Fill in the missing entries. The
lights are counted from left to right, so the first bit is the first light, and so on.
11111
01111
11011
10011
00010
10010
11010
Chapter 15 Solutions
Introduction to Algorithms
Ch. 15.1 - Prob. 1ECh. 15.1 - Prob. 2ECh. 15.1 - Prob. 3ECh. 15.1 - Prob. 4ECh. 15.1 - Prob. 5ECh. 15.2 - Prob. 1ECh. 15.2 - Prob. 2ECh. 15.2 - Prob. 3ECh. 15.2 - Prob. 4ECh. 15.2 - Prob. 5E
Ch. 15.2 - Prob. 6ECh. 15.3 - Prob. 1ECh. 15.3 - Prob. 2ECh. 15.3 - Prob. 3ECh. 15.3 - Prob. 4ECh. 15.3 - Prob. 5ECh. 15.3 - Prob. 6ECh. 15.4 - Prob. 1ECh. 15.4 - Prob. 2ECh. 15.4 - Prob. 3ECh. 15.4 - Prob. 4ECh. 15.4 - Prob. 5ECh. 15.4 - Prob. 6ECh. 15.5 - Prob. 1ECh. 15.5 - Prob. 2ECh. 15.5 - Prob. 3ECh. 15.5 - Prob. 4ECh. 15 - Prob. 1PCh. 15 - Prob. 2PCh. 15 - Prob. 3PCh. 15 - Prob. 4PCh. 15 - Prob. 5PCh. 15 - Prob. 6PCh. 15 - Prob. 7PCh. 15 - Prob. 8PCh. 15 - Prob. 9PCh. 15 - Prob. 10PCh. 15 - Prob. 11PCh. 15 - Prob. 12P
Knowledge Booster
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.Similar questions
- We want to send n cargo by n truck. Each truck can move only one cargo and receives different costs for moving each of these cargoes. We want to move cargo with trucks so that we pay the lowest cost. First, write a backtracking algorithm for this purpose and then, explain How to reduce the branch and the complexity of the algorithm with an algorithm(Pseudocode is required for backtracking algorithm. In the branch and limit algorithm, it is sufficient to explain the limit function and the method of pruning.)arrow_forwardhe heuristic path algorithm is a best-first search in which the objective function is f(n) = (4 −w)g(n) + wh(n). For what values of w is this algorithm guaranteed to be optimal? What kind of search does this perform when w = 0? When w = 1? When w = 4?arrow_forwardWe are to complete a set of n jobs using m identical machines. Each job has a known duration. The goal is to schedule the jobs on m machines so that the time to finish the last job is as small as possible. Once a job is scheduled on a machine, it can’t be stopped and restarted. Any job can run on any machine. A greedy algorithm to solve this problem is as follows: sort jobs in decreasing order of duration. Schedule jobs one by one, choosing the machine where it can start the earliest. a. For m = 3 and n = 6 where the durations are <9, 12, 3, 8, 6, 5>, what is the finish time of the last job using greedy schedule? b. Exhibit an input for which the greedy schedule is NOT optimal.arrow_forward
- A numeric array of length N is given. We need to design a function that finds all positive numbers in the array. a) Describe approaches for solving optimal worst case and optimal average case performance, respectively.arrow_forwardThere are n people who want to carpool during m days. On day i, some subset si ofpeople want to carpool, and the driver di must be selected from si . Each person j hasa limited number of days fj they are willing to drive. Give an algorithm to find a driverassignment di ∈ si each day i such that no person j has to drive more than their limit fj. (The algorithm should output “no” if there is no such assignment.) Hint: Use networkflow.For example, for the following input with n = 3 and m = 3, the algorithm could assignTom to Day 1 and Day 2, and Mark to Day 3. Person Day 1 Day 2 Day 3 Limit 1 (Tom) x x x 2 2 (Mark) x x 1 3 (Fred) x x 0arrow_forwardWrite a recurrence that would be used in dynamic programming for thefollowing problem: Given a rod of length n and an array A of prices thatcontain all prices of all the pieces smaller than n. Determine the maximumvalue obtained by cutting up the rod and selling the pieces. Note that youcould sell the rod at its original length without cutting it.arrow_forward
- You have m dollars and a group of n friends. For each friend 1 ≤ i ≤n, you know the price P[i] of the piece of candy that would make your friend happy. You want to find a way to distribute the m dollars such that as many of your friends as possible are happy. Design an O(n log n) time greedy algorithm to find how much money you will allocate each friend.arrow_forwardConsider navigating the maze shown below (same maze used in the homework). (N M 4 2 K 2 2 2 E B G 2 2 F H 2 The maze is represented as a graph with edge costs as shown on the edges. The edge cost is 1 for all edges where the cost is not shown. Let B be the initial state and G is the goal state. The heuristic cost of every node to reach G is : h(n) Th A 5.1 B 4.1 C 3.9 D 14 E 2.2 IF 3.8 G 0 IH 3.7 IJ 7 IK 16 L 14 IM 0.5 IN 1.5 IP 1.8 S 4.5 Show the steps of an A* search starting from B to goal G: . Show the frontier and explored set in every iteration (i.e., complete the above table) List the vertices in the order they are expanded.arrow_forwardThere are two proposed algorithms for X, which we will call Solution Aand Solution B. Solution A takes 9n + 6 steps to run for an input of size n. Solution Btakes 2(n2) + 1 steps to run for an input of size n.How many steps will it take for both algorithms to solve Problem X if n is 10? How about if n is 30? What if n is 100? For what range of values would Solution A be the better choice? What about Solution B? Are there any values where it does not matter which solution you use? If so whichones?arrow_forward
- Suppose a salesperson is planning a sales trip that includes n cities. Each city is connected to some of the other cities by a road. To minimize travel time, the salesperson wants to determine the shortest route that starts at the salesperson’s home city, visits each of the cities once, and ends up at the home city. This problem of finding the shortest route is called the Travelling Salesperson Problem (TSP) and is a well-known problem that can be solved using Dynamic Programming. Research about the TSP problem and find an algorithm based on Dynamic Programming for that. Explain the approach, the algorithm, and its time complexity. Use an example to explain the way the algorithm operatesarrow_forwardA ski rental agency has n pairs of skis, where the height of the the ith pair of skis is si . There are n skiers who wish to rent skis, where the height of the ith skier is hi. Ideally, each skier should obtain a pair of skis whose height matches her/his own height as closely as possible. We would like to assign skis to skiers so that the sum of the absolute differences of the heights of each skier and her/his skis is minimized. Design a greedy algorithm for the problem. Prove the correctness of your algorithm. (Hint: Start with two skis and two skiers. How would you match them? Continue to three skis and three skiers, and identify a strategy.)arrow_forwardAssuming you possess a total of 'm' dollars, and are accompanied by a group of 'n' friends. For every friend i, where i ranges from 1 to n, the price P[i] of the candy that would bring contentment to the respective friend is known. The objective is to devise a method for allocating a sum of m dollars in a manner that maximizes the number of contented friends. Propose an O(n log n) time greedy algorithm for determining the monetary allocation to be assigned to each friend.arrow_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