+ All Categories
Home > Documents > 2.3 Recursion

2.3 Recursion

Date post: 02-Feb-2016
Category:
Upload: sadie
View: 31 times
Download: 0 times
Share this document with a friend
Description:
2.3 Recursion. M. C. Escher, 1948. Overview. What is recursion? When one function calls itself directly or indirectly. Why learn recursion? Occurs in nature New way of thinking about programming Powerful programming paradigm. Many computations are naturally self-referential. - PowerPoint PPT Presentation
15
2.3 Recursion M. C. Escher, 1948
Transcript
Page 1: 2.3  Recursion

2.3 Recursion

M. C. Escher, 1948

Page 2: 2.3  Recursion

2

Overview

What is recursion? When one function calls itself directly or indirectly.

Why learn recursion? Occurs in nature New way of thinking about programming Powerful programming paradigm.

Many computations are naturally self-referential. Mergesort, FFT, gcd. A folder contains files and other folders.

Closely related to mathematical induction.M. C. Escher, 1948

Page 3: 2.3  Recursion

3

Greatest Common Divisor

Gcd. Find largest integer that evenly divides into p and q.

Ex. gcd(4032, 1272) = 24.

Applications. Simplify fractions: 1272/4032 = 53/168. RSA cryptosystem.

4032 = 26 32 71

1272 = 23 31 531

gcd = 23 31 = 24

Page 4: 2.3  Recursion

4

Greatest Common Divisor

Gcd. Find largest integer that evenly divides into p and q.

Euclid's algorithm. [Euclid 300 BCE]

gcd(4032, 1272) = gcd(1272, 216)

= gcd(216, 192)

= gcd(192, 24)

= gcd(24, 0)

= 24.

base case

reduction step,converges to base case

4032 = 3 1272 + 216

Page 5: 2.3  Recursion

5

Greatest Common Divisor

Gcd. Find largest integer d that evenly divides into p and q.

Java implementation.

base casereduction step

public static int gcd(int p, int q) { if (q == 0) return p; else return gcd(q, p % q);}

base case

reduction step,converges to base case

Page 6: 2.3  Recursion

6

How-To’s on Writing Recursive Functions

Base Case: You must check if we’ve reached the base case before doing

another level of recursion!

Make Progress Towards Base Case: Your recursive calls must be on a smaller or simpler input. Eventually this must reach the base case (and not miss it).

Multiple recursive calls: Sometimes more than one recursive call. Sometimes not. Are their return values chosen, combined?

Learn and follow these rules carefully!

Page 7: 2.3  Recursion

Recursive Graphics

Page 8: 2.3  Recursion

8

Page 9: 2.3  Recursion

9

H-tree

Used in integrated circuits to distribute the clock signal.

H-tree of order n. Draw an H. Recursively draw 4 H-trees of order n-1, one connected to each tip.

and half the size

order 1 order 2 order 3

tip

size

Page 10: 2.3  Recursion

10

Page 11: 2.3  Recursion

11

Htree in JavaDr. Java Demo

public class Htree { public static void draw(int n, double sz, double x, double y) { if (n == 0) return; double x0 = x - sz/2, x1 = x + sz/2; double y0 = y - sz/2, y1 = y + sz/2;

StdDraw.line(x0, y, x1, y); StdDraw.line(x0, y0, x0, y1); StdDraw.line(x1, y0, x1, y1);

draw(n-1, sz/2, x0, y0); draw(n-1, sz/2, x0, y1); draw(n-1, sz/2, x1, y0); draw(n-1, sz/2, x1, y1); }

public static void main(String[] args) { int n = Integer.parseInt(args[0]); draw(n, .5, .5, .5); }}

draw the H, centered on (x, y)

recursively draw 4 half-size Hs

Page 12: 2.3  Recursion

Computational Cost of the H-Tree Program

H-tree of Order 1 First invocation of draw() calls itself 4

times

H-tree of Order 2?

12

Page 13: 2.3  Recursion

13

Towers of Hanoi

http://en.wikipedia.org/wiki/Image:Hanoiklein.jpg

Page 14: 2.3  Recursion

14

Towers of Hanoi

Move all the discs from the leftmost peg to the rightmost one. Only one disc may be moved at a time. A disc can be placed either on empty peg or on top of a larger

disc.

Towers of Hanoi demo

start finish

Edouard Lucas (1883)

Page 15: 2.3  Recursion

15

Towers of Hanoi: Recursive Solution

Move n-1 smallest discs right.

Move n-1 smallest discs right. Move largest disc left.

cyclic wrap-around


Recommended