dynamic programming adapted from introduction and algorithms by kleinberg and tardos
Post on 22-Dec-2015
231 views
TRANSCRIPT
![Page 1: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/1.jpg)
Dynamic Programming
Adapted from Introduction and Algorithms by Kleinberg and Tardos.
![Page 2: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/2.jpg)
2
Weighted Activity Selection
Weighted activity selection problem (generalization of CLR 17.1). Job requests 1, 2, … , N. Job j starts at sj, finishes at fj , and has weight wj .
Two jobs compatible if they don't overlap. Goal: find maximum weight subset of mutually compatible jobs.
Time0
A
C
F
B
D
G
E
1 2 3 4 5 6 7 8 9 10 11
H
![Page 3: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/3.jpg)
3
Activity Selection: Greedy Algorithm
Recall greedy algorithm works if all weights are 1.
Sort jobs by increasing finish times so thatf1 f2 ... fN.
S = FOR j = 1 to N IF (job j compatible with A) S S {j}RETURN S
Greedy Activity Selection Algorithm
S = jobs selected.
![Page 4: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/4.jpg)
4
Weighted Activity Selection
Notation. Label jobs by finishing time: f1 f2 . . . fN .
Define qj = largest index i < j such that job i is compatible with j.
– q7 = 3, q2 = 0
Time0
3
2
6
1
5
7
4
1 2 3 4 5 6 7 8 9 10 11
8
![Page 5: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/5.jpg)
5
Weighted Activity Selection: Structure
Let OPT(j) = value of optimal solution to the problem consisting of job requests {1, 2, . . . , j }.
Case 1: OPT selects job j.
– can't use incompatible jobs { qj + 1, qj + 2, . . . , j-1 }
– must include optimal solution to problem consisting of remaining compatible jobs { 1, 2, . . . , qj }
Case 2: OPT does not select job j.– must include optimal solution to problem consisting of
remaining compatible jobs { 1, 2, . . . , j - 1 }
otherwise)1(),(max
0j if0)(
jOPTqOPTwjOPT
jj
![Page 6: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/6.jpg)
6
Weighted Activity Selection: Brute Force
INPUT: N, s1,…,sN , f1,…,fN , w1,…,wN
Sort jobs by increasing finish times so thatf1 f2 ... fN.
Compute q1, q2 , ... , qN
r-compute(j) { IF (j = 0) RETURN 0 ELSE return max(wj + r-compute(qj), r-compute(j-1))}
Recursive Activity Selection
![Page 7: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/7.jpg)
7
Dynamic Programming Subproblems
Spectacularly redundant subproblems exponential algorithms.
1, 2, 3, 4, 5, 6, 7, 8
1, 2, 3, 4, 5, 6, 71, 2, 3, 4, 5
1, 2, 3, 4, 5, 61, 2, 3 1, 2, 3, 4
1 1, 2, 3 1, 2 1, 2 1, 2, 3, 4, 5
1 . . . . . . . . .
![Page 8: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/8.jpg)
8
Divide-and-Conquer Subproblems
Independent subproblems efficient algorithms.
1, 2, 3, 4, 5, 6, 7, 8
1, 2, 3, 4
1, 2 3, 4
3 41 2
5, 6, 7, 8
5, 6 7, 8
7 85 6
![Page 9: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/9.jpg)
9
Weighted Activity Selection: Memoization
INPUT: N, s1,…,sN , f1,…,fN , w1,…,wN
Sort jobs by increasing finish times so thatf1 f2 ... fN.
Compute q1, q2 , ... , qN
Global array OPT[0..N]FOR j = 0 to N OPT[j] = "empty"
m-compute(j) { IF (j = 0) OPT[0] = 0 ELSE IF (OPT[j] = "empty") OPT[j] = max(wj + m-compute(qj), m-compute(j-1)) RETURN OPT[j]}
Memoized Activity Selection
![Page 10: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/10.jpg)
10
Weighted Activity Selection: Running Time
Claim: memoized version of algorithm takes O(N log N) time. Ordering by finish time: O(N log N). Computing qj : O(N log N) via binary search.
m-compute(j): each invocation takes O(1) time and either– (i) returns an existing value of OPT[]– (ii) fills in one new entry of OPT[] and makes two recursive calls
Progress measure = # nonempty entries of OPT[]. Initially = 0, throughout N. (ii) increases by 1 at most 2N recursive calls.
Overall running time of m-compute(N) is O(N).
![Page 11: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/11.jpg)
11
Weighted Activity Selection: Finding a Solution
m-compute(N) determines value of optimal solution. Modify to obtain optimal solution itself.
# of recursive calls N O(N).
ARRAY: OPT[0..N]Run m-compute(N)
find-sol(j) { IF (j = 0) output nothing ELSE IF (wj + OPT[qj] > OPT[j-1]) print j find-sol(qj) ELSE find-sol(j-1)}
Finding an Optimal Set of Activities
![Page 12: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/12.jpg)
12
Weighted Activity Selection: Bottom-Up
Unwind recursion in memoized algorithm.
INPUT: N, s1,…,sN , f1,…,fN , w1,…,wN
Sort jobs by increasing finish times so thatf1 f2 ... fN.
Compute q1, q2 , ... , qN
ARRAY: OPT[0..N]OPT[0] = 0
FOR j = 1 to N OPT[j] = max(wj + OPT[qj], OPT[j-1])
Bottom-Up Activity Selection
![Page 13: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/13.jpg)
13
Dynamic Programming Overview
Dynamic programming. Similar to divide-and-conquer.
– solves problem by combining solution to sub-problems Different from divide-and-conquer.
– sub-problems are not independent– save solutions to repeated sub-problems in table– solution usually has a natural left-to-right ordering
Recipe. Characterize structure of problem.
– optimal substructure property Recursively define value of optimal solution. Compute value of optimal solution. Construct optimal solution from computed information.
Top-down vs. bottom-up: different people have different intuitions.
![Page 14: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/14.jpg)
14
Least Squares
Least squares. Foundational problem in statistic and numerical analysis. Given N points in the plane { (x1, y1), (x2, y2) , . . . , (xN, yN) },
find a line y = ax + b that minimizes the sum of the squared error:
Calculus min error is achieved when:
N
iii baxySS
1
2)(
N
xayb
xxN
yxyxNa i i ii
i i ii
i i ii iii
,)(
)()(22
![Page 15: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/15.jpg)
15
Segmented Least Squares
Segmented least squares. Points lie roughly on a sequence of 3 lines. Given N points in the plane p1, p2 , . . . , pN , find a sequence of
lines that minimize:– the sum of the sum of the squared errors E in each segment– the number of lines L
Tradeoff function: e + c L, for some constant c > 0.
3 lines better than one
![Page 16: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/16.jpg)
16
Segmented Least Squares: Structure
Notation. OPT(j) = minimum cost for points p1, pi+1 , . . . , pj .
e(i, j) = minimum sum of squares for points pi, pi+1 , . . . , pj
Optimal solution: Last segment uses points pi, pi+1 , . . . , pj for some i.
Cost = e(i, j) + c + OPT(i-1).
New dynamic programming technique. Weighted activity selection: binary choice. Segmented least squares: multi-way choice.
otherwise)1(),(min
0j if0)(
1iOPTcjiejOPT
ji
![Page 17: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/17.jpg)
17
Segmented Least Squares: Algorithm
Running time: Bottleneck = computing e(i, n) for O(N2) pairs, O(N) per pair using
previous formula. O(N3) overall.
INPUT: N, p1,…,pN , c
ARRAY: OPT[0..N]OPT[0] = 0
FOR j = 1 to N FOR i = 1 to j compute the least square error e[i,j] for the segment pi,..., pj
OPT[j] = min1 i j (e[i,j] + c + OPT[i-1])
RETURN OPT[N]
Bottom-Up Segmented Least Squares
![Page 18: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/18.jpg)
18
Segmented Least Squares: Improved Algorithm
A quadratic algorithm. Bottleneck = computing e(i, j). O(N2) preprocessing + O(1) per computation.
22
22
j
ikk
j
ikk
j
ikk
j
ikk
j
ikkk
ij
xxn
yxyxn
a
i
kkkk
i
kkk
i
kkk
yxxy
xxxs
xxs
1
1
2
1
i
kkk
i
kkk
yyys
yys
1
2
11
ij
j
ikk xsxsx
)(
)(),(
1
2
ij
j
ikkk
yysyys
baxyjie
1
ijn
n
xayb
ij
j
ikk
j
ikk
ij
Preprocessing
![Page 19: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/19.jpg)
19
Knapsack Problem
Knapsack problem. Given N objects and a "knapsack." Item i weighs wi > 0 Newtons and has value vi > 0.
Knapsack can carry weight up to W Newtons. Goal: fill knapsack so as to maximize total value.
Item Value Weight
1 1 1
2 6 2
3 18 5
4 22 6
5 28 7
W = 11
OPT value = 40: { 3, 4 }
Greedy = 35: { 5, 2, 1 }
vi / wi
![Page 20: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/20.jpg)
20
Knapsack Problem: Structure
OPT(n, w) = max profit subset of items {1, . . . , n} with weight limit w. Case 1: OPT selects item n.
– new weight limit = w – wn
– OPT selects best of {1, 2, . . . , n – 1} using this new weight limit Case 2: OPT does not select item n.
– OPT selects best of {1, 2, . . . , n – 1} using weight limit w
New dynamic programming technique. Weighted activity selection: binary choice. Segmented least squares: multi-way choice. Knapsack: adding a new variable.
otherwise),1(),,1(max
ww if),1(
0n if0
),( n
nn wwnOPTvwnOPT
wnOPTwnOPT
![Page 21: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/21.jpg)
21
Knapsack Problem: Bottom-Up
INPUT: N, W, w1,…,wN, v1,…,vN
ARRAY: OPT[0..N, 0..W]
FOR w = 0 to W OPT[0, w] = 0
FOR n = 1 to N FOR w = 1 to W IF (wn > w) OPT[n, w] = OPT[n-1, w] ELSE OPT[n, w] = max {OPT[n-1, w], vn + OPT[n-1, w-wn ]}
RETURN OPT[N, W]
Bottom-Up Knapsack
![Page 22: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/22.jpg)
22
Knapsack Algorithm
Weight Limit 0
{1} 0
{1, 2} 0
{1, 2, 3} 0
{1, 2, 3, 4} 0
{1, 2, 3, 4, 5} 0
0
1
1
1
1
1
1
0
2
1
6
6
6
6
0
3
1
7
7
7
7
0
4
1
7
7
7
7
0
5
1
7
18
18
18
0
6
1
7
19
22
22
0
7
1
7
24
24
28
0
8
1
7
25
28
29
0
9
1
7
25
29
34
0
10
1
7
25
29
35
0
11
1
7
25
40
40
0
Item Value Weight
1 1 1
2 6 2
3 8 5
4 22 6
5 28 7
N + 1
W + 1
![Page 23: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/23.jpg)
23
Knapsack Problem: Running Time
Knapsack algorithm runs in time O(NW). Not polynomial in input size! "Pseudo-polynomial." Decision version of Knapsack is "NP-complete." Optimization version is "NP-hard."
Knapsack approximation algorithm. There exists a polynomial algorithm that produces a feasible
solution that has value within 0.01% of optimum. Stay tuned.
![Page 24: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/24.jpg)
24
Sequence Alignment
How similar are two strings? ocurrance occurrence
o c u r r a n c e
c c u r r e n c eo
o c u r r n c e
c c u r r n c eo
a
e
o c u r r a n c e
c c u r r e n c eo
5 mismatches, 1 gap
1 mismatch, 1 gap 0 mismatches, 3 gaps
![Page 25: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/25.jpg)
25
Industrial Application
![Page 26: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/26.jpg)
26
2 + CA
C G A C C T A C C T
C T G A C T A C A T
T G A C C T A C C T
C T G A C T A C A T
T
C
C
C
TC + GT + AG+ 2CA
Sequence Alignment: Applications
Applications. Spell checkers / web dictionaries.
– ocurrance– occurrence
Computational biology.– ctgacctacct– cctgactacat
Edit distance. Needleman-Wunsch, 1970. Gap penalty . Mismatch penalty pq.
Cost = sum of gap andmismatch penalties.
![Page 27: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/27.jpg)
27
Problem. Input: two strings X = x1 x2 . . . xM and Y = y1 y2 . . . yN.
Notation: {1, 2, . . . , M} and {1, 2, . . . , N} denote positions in X, Y. Matching: set of ordered pairs (i, j) such that each item occurs in
at most one pair. Alignment: matching with no crossing pairs.
– if (i, j) M and (i', j') M and i < i', then j < j'
Example: CTACCG vs. TACATG.– M = { (2,1) (3,2) (4,3), (5,4), (6,6) }
Goal: find alignment of minimum cost.
Sequence Alignment
gap
),(:),(:
mismatch
),()(cost
MjijMjiiMjiyx ji
M
C T A C C
T A C A T
G
G
![Page 28: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/28.jpg)
28
Sequence Alignment: Problem Structure
OPT(i, j) = min cost of aligning strings x1 x2 . . . xi and y1 y2 . . . yj .
Case 1: OPT matches (i, j).– pay mismatch for (i, j) + min cost of aligning two strings
x1 x2 . . . xi-1 and y1 y2 . . . yj-1
Case 2a: OPT leaves m unmatched.
– pay gap for i and min cost of aligning x1 x2 . . . xi-1 and y1 y2 . . . yj
Case 2b: OPT leaves n unmatched.
– pay gap for j and min cost of aligning x1 x2 . . . xi and y1 y2 . . . yj-1
0j if
otherwise
)1,(
),,1(
),1,1(
min
0i if
),(
i
jiOPT
jiOPT
jiOPTj
jiOPTji yx
![Page 29: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/29.jpg)
29
Sequence Alignment: Algorithm
O(MN) time and space.
INPUT: M, N, x1x2...xM, y1y2...yN, ,
ARRAY: OPT[0..M, 0..N]
FOR i = 0 to M OPT[0, i] = iFOR j = 0 to N OPT[j, 0] = j
FOR i = 1 to M FOR j = 1 to N OPT[i, j] = min([xi, yj] + OPT[i-1, j-1], + OPT[i-1, j], + OPT[i, j-1])RETURN OPT[M, N]
Bottom-Up Sequence Alignment
![Page 30: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/30.jpg)
30
Sequence Alignment: Linear Space
Straightforward dynamic programming takes (MN) time and space. English words or sentences may not be a problem. Computational biology huge problem.
– M = N = 100,000– 10 billion ops OK, but 10 gigabyte array?
Optimal value in O(M + N) space and O(MN) time. Only need to remember OPT( i - 1, •) to compute OPT( i, •). Not clear how to recover optimal alignment itself.
Optimal alignment in O(M + N) space and O(MN) time. Clever combination of divide-and-conquer and dynamic
programming.
![Page 31: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/31.jpg)
31
Consider following directed graph (conceptually). Note: takes (MN) space to write down graph.
Let f(i, j) be shortest path from (0,0) to (i, j). Then, f(i, j) = OPT(i, j).
Sequence Alignment: Linear Space
M-N
x1
x2
y1
x3
y2 y3 y4 y5 y6
0-0
ji yx
i-j
![Page 32: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/32.jpg)
32
Let f(i, j) be shortest path from (0,0) to (i, j). Then, f(i, j) = OPT(i, j). Base case: f(0, 0) = OPT(0, 0) = 0. Inductive step: assume f(i', j') = OPT(i', j') for all i' + j' < i + j. Last edge on path to (i, j) is either from (i-1, j-1), (i-1, j), or (i, j-1).
Sequence Alignment: Linear Space
),(
})1,(),,1(),1,1({min
})1,(),,1(),1,1({min),(
jiOPT
jiOPTjiOPTjiOPT
jifjifjifjif
ji
ji
yx
yx
M-N
x1
x2
y1
x3
y2 y3 y4 y5 y6
0-0
jiyx
i-j
![Page 33: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/33.jpg)
33
Let g(i, j) be shortest path from (i, j) to (M, N). Can compute in O(MN) time for all (i, j) by reversing arc
orientations and flipping roles of (0, 0) and (M, N).
Sequence Alignment: Linear Space
M-N
x1
x2
y1
x3
y2 y3 y4 y5 y6
0-0
ji yx
i-j
![Page 34: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/34.jpg)
34
Observation 1: the cost of the shortest path that uses (i, j) isf(i, j) + g(i, j).
Sequence Alignment: Linear Space
i-j
M-N
x1
x2
y1
x3
y2 y3 y4 y5 y6
0-0
![Page 35: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/35.jpg)
35
Observation 1: the cost of the shortest path that uses (i, j) isf(i, j) + g(i, j).
Observation 2: let q be an index that minimizes f(q, N/2) + g(q, N/2). Then, the shortest path from (0, 0) to (M, N) uses (q, N/2).
Sequence Alignment: Linear Space
i-j
M-N
x1
x2
y1
x3
y2 y3 y4 y5 y6
0-0
![Page 36: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/36.jpg)
36
Divide: find index q that minimizes f(q, N/2) + g(q, N/2) using DP.
Conquer: recursively compute optimal alignment in each "half."
Sequence Alignment: Linear Space
i-j
M-N
x1
x2
y1
x3
y2 y3 y4 y5 y6
0-0
N / 2
![Page 37: Dynamic Programming Adapted from Introduction and Algorithms by Kleinberg and Tardos](https://reader036.vdocuments.site/reader036/viewer/2022062715/56649d815503460f94a6585d/html5/thumbnails/37.jpg)
37
T(m, n) = max running time of algorithm on strings of length m and n.
Theorem. T(m, n) = O(mn). O(mn) work to compute f (• , n / 2) and g (• , n / 2). O(m + n) to find best index q. T(q, n / 2) + T(m - q, n / 2) work to run recursively. Choose constant c so that:
Base cases: m = 2 or n = 2. Inductive hypothesis: T(m, n) 2cmn.
Sequence Alignment: Linear Space
cmn
cmncqncmncqn
cmnnqmccqn
cmnnqmTnqTnmT
2
2/)(22/2
)2/,()2/,(),(
)2/,()2/,(),(
)2,(
)2,(
nqmTnqTcmnnmT
cmnT
cnmT