02/07/2020 Design and analysis of algorithms - Course
(https://swayam.gov.in) (https://swayam.gov.in/nc_details/NPTEL)
reviewer4@nptel.iitm.ac.in
NPTEL (https://swayam.gov.in/explorer?ncCode=NPTEL) » Design and analysis of algorithms (course)
Announcements (announcements)
About the Course (https://swayam.gov.in/nd1_noc20_cs27/preview) Ask a Question (forum)
Progress (student/home) Mentor (student/mentor)
Week 6 Programming Assignment: Book
Course
outline
Cartons
Due on 2020-03-16, 23:59 IST
How does an Select your language (C/C++/Java/Python2/Python3)
NPTEL online Paste your code into the submission window.
course work? There are some public test cases and some (hidden) private test cases.
"Compile and run" will evaluate your submission against the public test
Week 1 : cases.
Introduction "Submit" will evaluate your submission against the hidden private test
cases. There are 10 private testcases in all, each with equal weightage.
Week 1 : You will get feedback about which private test cases pass or fail, though
Analysis of you cannot see the actual test cases.
algorithms For each private testcase, you will get a status 'Evaluated', 'Not Evaluated'
or 'Time Limit Exceeded'.
Week 1 Quiz 'Evaluated' does not mean your answer is correct, just that the entire
testcase completed and reported some answer.
Week 2 : 'Time Limit Exceeded' means your code took too long.
Searching and 'Not Evaluated' means this testcase was not run. This typically
sorting happens to all testcases after the first one that times out.
Ignore warnings about "Presentation errors".
Week 2 Quiz
Week 2
Programming
Assignment
Book cartons
A university department is shifting its department library to a more spacious
Week 3 : Graphs room on a newly constructed floor. The books from the library have been
packed into m cartons, numbered 1, 2, …, m, containing b1, b2, …, bm books,
Week 3 Quiz respectively, and transported to the new library room.
There are k student volunteers available to unpack the m cartons, where k ≤ m.
Each carton must be assigned to a single volunteer, and every volunteer must
t t ti f t t k
https://onlinecourses.nptel.ac.in/noc20_cs27/progassignment?name=122 1/6
02/07/2020 Design and analysis of algorithms - Course
get a non-empty continuous sequence of cartons to unpack.
Week 3
Programming More formally, we need to find numbers 0 = c0 < c1 < c2 < … < ck = m such that
Assignment volunteer j, 1 ≤ j ≤ k unpacks cartons cj-1+1 to cj.
The time each volunteer takes to unpack a carton is directly proportional to the
Week 4 : number of books in the carton. The goal is parallelize the unpacking to finish in
Weighted the fastest possible time. For this, we need to assign cartons such that the
graphs
maximum number of books assigned to any one volunteer is minimized.
Week 4 Quiz
Solution hint
Week 4
Programming Given a target T, use a greedy strategy to check if there is a legal allocation
Assignment where no volunteer is assigned more than T books. Find the optimum T using
binary search. Note that if a greedy strategy finds an allocation achieving target
Week 5: Data T using k' < k volunteers, this allocation can always be subdivided to achieve
Structures: the same target with exactly k volunteers.
Union-Find and
Input format
Heaps
Week 5 : Divide
Each test case consists of exactly two lines. The first line has are two integers
and Conqure
m and k. The second line has m integers b1, b2, …, bm separated by spaces.
Week 5 Quiz
Week 6: Data
Output format
Structures: Your output should be a single line with the input sequence b1, b2, …, bm
Search Trees divided into exactly k parts such that the maximum sum in a single part is as
small as possible. Use the slash character ('/') to separate the parts. There
Week 6: Greedy must be exactly one space character between any two successive numbers and
Algorithms between the number and the slash. If there is more than one solution, print the
one that minimizes the work assigned to the first volunteer, then to the second
Week 6 Quiz volunteer etc. Each volunteer must be assigned at least one carton.
Week 6
Programming Test Data:
Assignment
You may assume that 1 ≤ k ≤ m ≤ 500, always. Also, each carton contains a
Week 6 positive number of books, which is less than 10,000,000.
Programming
Assignment:
Book Cartons Sample Input 1:
(/noc20_cs27/progassignment?
name=122)
9 3
Week 7: 100 200 300 400 500 600 700 800 900
Dynamic
Programming
Week 7 Quiz
Sample Output 1:
Week 7 100 200 300 400 500 / 600 700 / 800 900
Programming
Assignment
Sample Input 2:
https://onlinecourses.nptel.ac.in/noc20_cs27/progassignment?name=122 2/6
02/07/2020 Design and analysis of algorithms - Course
Week 8: Linear
5 4
Programming
100 100 100 100 100
and Network
Flows
Week 8: Sample Output 2:
Intractability
100 / 100 / 100 / 100 100
Week 8 Quiz
Text Transcripts
Books Sample Test Cases
Input Output
Download 17 4
Videos Test 100 200 300 400 500 100 200 300 400 500 / 600 700
Case 600 700 800 900 800 800 / 900 800 700 / 600 500 40
1 700 600 500 400 300 0 300 200 100
200 100
100 99
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
Test 100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
Case 100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
2 100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 / 100 /
100 100 100 100 100
100 / 100 / 100 / 100 100
100 100 100 100 100
Test
500 499 100 / 100 / 100 / 100 / 100 /
Case
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
3
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
https://onlinecourses.nptel.ac.in/noc20_cs27/progassignment?name=122 3/6
02/07/2020 Design and analysis of algorithms - Course
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
https://onlinecourses.nptel.ac.in/noc20_cs27/progassignment?name=122 4/6
02/07/2020 Design and analysis of algorithms - Course
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 / 100 /
100 100 100 100 100 100 / 100 / 100 / 100 100
100 100 100 100 100
Test
4 2
Case 1 2 4 / 8
1 2 4 8
4
Test
6 2
Case 1 2 4 / 8 4 2
1 2 4 8 4 2
5
Test
6 2
Case 1 2 3 / 3 2 1
1 2 3 3 2 1
6
Test
2 2
Case 10000000 / 10000000
10000000 10000000
7
https://onlinecourses.nptel.ac.in/noc20_cs27/progassignment?name=122 5/6
02/07/2020 Design and analysis of algorithms - Course
Test
6 3
Case 1000000 / 1 / 1 1 1 1
1000000 1 1 1 1 1
8
Test
6 3
Case 1 / 1 1 1 1 / 10000000
1 1 1 1 1 10000000
9
Test
6 6
Case 6 / 5 / 4 / 3 / 2 / 1
6 5 4 3 2 1
10
Test 9 3
100 200 300 400 500 / 600 700
Case 100 200 300 400 500
/ 800 900
11 600 700 800 900
Test
5 4
Case 100 / 100 / 100 / 100 100
100 100 100 100 100
12
The due date for submitting this assignment has passed.
As per our records you have not submitted this assignment.
https://onlinecourses.nptel.ac.in/noc20_cs27/progassignment?name=122 6/6