KEMBAR78
Tutorial 02 | PDF | Vertex (Graph Theory) | Time Complexity
0% found this document useful (0 votes)
13 views2 pages

Tutorial 02

The document outlines a tutorial on the design and analysis of algorithms, focusing on various problems such as multiplying and adding n-digit integers using divide and conquer algorithms, finding the median of combined datasets with minimal queries, and implementing Horner's Rule for polynomial evaluation. It also covers advanced topics like the Fast Fourier Transform (FFT) algorithm, modular FFT, Cartesian sums of integer sets, and finding local minima in grid graphs. Each problem includes a requirement for time complexity analysis and algorithm implementation details.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
13 views2 pages

Tutorial 02

The document outlines a tutorial on the design and analysis of algorithms, focusing on various problems such as multiplying and adding n-digit integers using divide and conquer algorithms, finding the median of combined datasets with minimal queries, and implementing Horner's Rule for polynomial evaluation. It also covers advanced topics like the Fast Fourier Transform (FFT) algorithm, modular FFT, Cartesian sums of integer sets, and finding local minima in grid graphs. Each problem includes a requirement for time complexity analysis and algorithm implementation details.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 2

Tutorial 2, Design and Analysis of Algorithms, 2025

1. Design a divide and conquer algorithm for multiplying n-digit long integer to a
single digit. Derive its time complexity. (eg. 4 digit: 1234 multiplied by 5).
2. Design a divide and conquer algorithm for adding two n-digit long integers. Derive
its time complexity.
3. You are interested in analyzing some hard-to-obtain data from two separate
databases. Each database contains n numerical values - so there are 2n val-
ues total - and you may assume that no two values are the same. You would like
to determine the median of this set of 2n values, which we will de ne here to
be the n'th smallest value. However, the only way you can access these values is
through queries to the databases. In a single query, you can specify a value k to
one of the two databases, and the chosen database will return the k'th smallest
value that it contains. Since queries are expensive, you would like to compute the
median using as few queries as possible. Give an algorithm that nds the median
value using at most O(log n) queries.
4. Horner’s Rule to evaluate a polynomial of the form a0 + a1 x + a2 x2 + ::: + an xn
devices a strategy that computes the polynomial in a way similar to a0 + x(a1 +
x(a2 + ::: + n(an 1 + xan ) :::). Write a pseudocode to implement Horner's rule
and also give proof of its correctness by clearly providing loop invariant.
5. (a) Find the number of nodes in the divide and conquer graph for computing
FFT of a vector of length n (for simplicity you can assume n to be a power
of 2).
(b) Now nd time complexity of the FFT algorithm by only considering the
structure of the divide and conquer graph (without solving any recursion).
6. Find 1212  2121 using the FFT algorithm showing its divide and conquer graphs.
7. (a) Describe the generalization of the FFT procedure to the case in which n is
a power of 3 (using three subproblems). Give a recurrence for the running
time, and solve the recurrence.
(b) Find 97  68 using the above algorithm showing its divide and conquer graphs.
8. In the Modular FFT Algorithm, instead of performing an n element FFT over
complex numbers (where n is even), we use the complete residue system modulo
m (Zm ), where m = 2tn=2 + 1 and t is an arbitrary positive integer. Instead of ad-
dition of complex numbers, we use addition modulo m. Instead of multiplication
of complex numbers, we use multiplication modulo m. We use ! = 2t instead of
!n as a principal nth root of unity, modulo m. Instead of !n 1 , we use the inverse
! 1 of ! computed in Zm using ecient algorithms. Find (2x +1)  (3x +2) using

1
the Modular FFT Algorithm (by taking t = 8) showing its divide and conquer
graphs.
9. Consider two sets A and B , each having n integers in the range from 0 to 10n.
We wish to compute the Cartesian sum of A and B , de ned by
C = f x + y j x 2 A;y 2 B g.
Note that the integers in C are in the range from 0 to 20n. We want to nd the
elements of C and the number of times each element of C is realized as a sum of
elements in A and B . Design an O(n log n)-time algorithm to solve this problem.
10. Consider an n  n grid graph G. (An n  n grid graph is just the adjacency graph
of an n  n chessboard. To be completely precise, it is a graph whose node set is
the set of all ordered pairs of natural numbers (i;j ), where 1  i  n and 1  j  n;
the nodes (i;j ) and (k;l) are joined by an edge if and only if ji kj + jj lj = 1.)
Each node v of G is labeled with a real number xv . You may assume that the real
numbers labeling the nodes are all distinct. A node v of G is a local minimum
if the label xv is less than the label xw for all nodes w that are joined to v by an
edge. You are given such an n  n grid graph G, but the labeling is only speci ed
in the following implicit way: for each node v , you can determine the value xv
by probing the node v . Show how to nd a local minimum of G using only O(n)
probes to the nodes of G. Give a proof of correctness of your algorithm and also
prove its time complexity.

You might also like