Pearls of Functional Algorithm Design

Pearls of Functional Algorithm Design

by Richard Bird
ISBN-10:
0521513383
ISBN-13:
9780521513388
Pub. Date:
09/16/2010
Publisher:
Cambridge University Press
ISBN-10:
0521513383
ISBN-13:
9780521513388
Pub. Date:
09/16/2010
Publisher:
Cambridge University Press
Pearls of Functional Algorithm Design

Pearls of Functional Algorithm Design

by Richard Bird
$71.99 Current price is , Original price is $71.99. You
$71.99 
  • SHIP THIS ITEM
    Qualifies for Free Shipping
  • PICK UP IN STORE
    Check Availability at Nearby Stores
  • SHIP THIS ITEM

    Temporarily Out of Stock Online

    Please check back later for updated availability.


Overview

Richard Bird takes a radically new approach to algorithm design, namely, design by calculation. These 30 short chapters each deal with a particular programming problem drawn from sources as diverse as games and puzzles, intriguing combinatorial tasks, and more familiar areas such as data compression and string matching. Each pearl starts with the statement of the problem expressed using the functional programming language Haskell, a powerful yet succinct language for capturing algorithmic ideas clearly and simply. The novel aspect of the book is that each solution is calculated from an initial formulation of the problem in Haskell by appealing to the laws of functional programming. Pearls of Functional Algorithm Design will appeal to the aspiring functional programmer, students and teachers interested in the principles of algorithm design, and anyone seeking to master the techniques of reasoning about programs in an equational style.

Product Details

ISBN-13: 9780521513388
Publisher: Cambridge University Press
Publication date: 09/16/2010
Pages: 290
Product dimensions: 6.70(w) x 9.90(h) x 0.80(d)

About the Author

Richard Bird is Professor of Computer Science at Oxford University Computing Laboratory.

Table of Contents

Preface ix

1 The smallest free number 1

2 A surpassing problem 7

3 Improving on saddleback search 12

4 A selection problem 21

5 Sorting pairwise sums 27

6 Making a century 33

7 Building a tree with minimum height 41

8 Unravelling greedy algorithms 50

9 Finding celebrities 56

10 Removing duplicates 64

11 Not the maximum segment sum 73

12 Ranking suffixes 79

13 The Burrows-Wheeler transform 91

14 The last tail 102

15 All the common prefixes 112

16 The Boyer-Moore algorithm 117

17 The Knuth-Morris-Pratt algorithm 127

18 Planning solves the Rush Hour problem 136

19 A simple Sudoku solver 147

20 The Countdown problem 156

21 Hylomorphisms and nexuses 168

22 Three ways of computing determinants 180

23 Inside the convex hull 188

24 Rational arithmetic coding 198

25 Integer arithmetic coding 208

26 The Schorr-Waite algorithm 221

27 Orderly insertion 231

28 Loopless functional algorithms 242

29 The Johnson-Trotter algorithm 251

30 Spider spinning for dummies 258

Index 275

From the B&N Reads Blog

Customer Reviews