ebook img

Mazes for Programmers: Code Your Own Twisty Little Passages PDF

278 Pages·2015·8.71 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Mazes for Programmers: Code Your Own Twisty Little Passages

Early praise for Mazes for Programmers Reading the book Mazes for Programmers is like a fun journey through a maze. There’s a good mix of simple explanations and working code, combined with ideas at the end of each chapter to inspire one to expand upon what was presented. ➤ Walter Pullen Author, “Think Labyrinth!” website Mazes for Programmers is full of nerdy algorithmic delight and is a really fun read! ➤ Bruce Williams CTO, CargoSense, Inc. Jamis Buck’s inspired choice of mazes as a unifying theme allows him to take the reader on a deeply engaging tour of an impressive array of algorithms and pro- gramming techniques. Mazes for Programmers is an exemplary book of its kind, ideal for programmers looking to take a break from tuition in specific programming languages and learn something of general interest and applicability within their craft. ➤ David A. Black Author, The Well-Grounded Rubyist My past 20 years as a software developer have taught me two things. First, I will probably never need to generate a maze. Second, and more important, pushing myself in new and unfamiliar ways is the best way for me to level up as a program- mer. Sure, Mazes for Programmers will teach you how to generate mazes, but it will also give you one of the clearest step-by-step tours through algorithmic thinking you can find. ➤ Chad Fowler CTO, Wunderlist This is a fun, playful tour of all the concepts and algorithms you’d want to know for generating and solving mazes. If only this book had existed when I was writing Maze Crusade! ➤ Amanda Wixted Owner, Meteor Grove Software I starting programming because of the fundamental joy of making cool things just for the sake of making cool things. Jamis’s Mazes for Programmers perfectly recap- tures that feeling of pure, unadulterated awesomeness for awesomeness’s sake. This will be a book I come back to again and again. ➤ Corey Haines CTO, Curious Nation This book reminded me of a simple fact I sometimes forget: programming is fun. ➤ Jeff Hardy Programmer, Basecamp Mazes for Programmers Code Your Own Twisty Little Passages Jamis Buck The Pragmatic Bookshelf Dallas, Texas • Raleigh, North Carolina Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and The Pragmatic Programmers, LLC was aware of a trademark claim, the designations have been printed in initial capital letters or in all capitals. The Pragmatic Starter Kit, The Pragmatic Programmer, Pragmatic Programming, Pragmatic Bookshelf, PragProg and the linking g device are trade- marks of The Pragmatic Programmers, LLC. Every precaution was taken in the preparation of this book. However, the publisher assumes no responsibility for errors or omissions, or for damages that may result from the use of information (including program listings) contained herein. Our Pragmatic courses, workshops, and other products can help you and your team create better software and have more fun. For more information, as well as the latest Pragmatic titles, please visit us at https://pragprog.com. The team that produced this book includes: Jacquelyn Carter (editor) Potomac Indexing, LLC (indexer) Liz Welch (copyeditor) Dave Thomas (typesetter) Janet Furlow (producer) Ellie Callahan (support) For international rights, please contact [email protected]. Copyright © 2015 The Pragmatic Programmers, LLC. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form, or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior consent of the publisher. Printed in the United States of America. ISBN-13: 978-1-68050-055-4 Encoded using the finest acid-free high-entropy binary digits. Book version: P1.0—July 2015 Contents Acknowledgments . . . . . . . . . . . ix Introduction . . . . . . . . . . . . . xi Part I — The Basics 1. Your First Random Mazes . . . . . . . . . . 3 Preparing the Grid 4 The Binary Tree Algorithm 6 The Sidewinder Algorithm 12 Your Turn 15 2. Automating and Displaying Your Mazes . . . . . . 17 Introducing Our Basic Grid 17 Implementing the Binary Tree Algorithm 22 Displaying a Maze on a Terminal 24 Implementing the Sidewinder Algorithm 27 Rendering a Maze as an Image 29 Your Turn 31 3. Finding Solutions . . . . . . . . . . . 35 Dijkstra’s Algorithm 36 Implementing Dijkstra’s 37 Finding the Shortest Path 42 Making Challenging Mazes 44 Coloring Your Mazes 47 Your Turn 51 4. Avoiding Bias with Random Walks . . . . . . . 53 Understanding Biases 53 The Aldous-Broder Algorithm 55 Contents • vi Implementing Aldous-Broder 57 Wilson’s Algorithm 60 Implementing Wilson’s Algorithm 63 Your Turn 65 5. Adding Constraints to Random Walks . . . . . . 67 The Hunt-and-Kill Algorithm 67 Implementing Hunt-and-Kill 69 Counting Dead Ends 71 The Recursive Backtracker Algorithm 73 Implementing the Recursive Backtracker 76 Your Turn 78 Part II — Next Steps 6. Fitting Mazes to Shapes . . . . . . . . . . 83 Introducing Masking 84 Implementing a Mask 86 ASCII Masks 90 Image Masks 92 Your Turn 94 7. Going in Circles . . . . . . . . . . . . 97 Understanding Polar Grids 98 Drawing Polar Grids 101 Adaptively Subdividing the Grid 103 Implementing a Polar Grid 104 Your Turn 111 8. Exploring Other Grids . . . . . . . . . . 113 Implementing a Hex Grid 113 Displaying a Hex Grid 117 Making Hexagon (Sigma) Mazes 120 Implementing a Triangle Grid 121 Displaying a Triangle Grid 124 Making Triangle (Delta) Mazes 126 Your Turn 127 9. Braiding and Weaving Your Mazes . . . . . . . 129 Braiding Mazes 130 Cost versus Distance 132 Contents • vii Implementing a Cost-Aware Dikstra’s Algorithm 134 Introducing Weaves and Insets 138 Generating Weave Mazes 144 Your Turn 151 Part III — More Algorithms 10. Improving Your Weaving . . . . . . . . . 157 Kruskal’s Algorithm 158 Implementing Randomized Kruskal’s Algorithm 164 Better Weaving with Kruskal 166 Implementing Better Weaving 168 Your Turn 172 11. Growing With Prim’s . . . . . . . . . . 175 Introducing Prim’s Algorithm 175 Simplified Prim’s Algorithm 179 True Prim’s Algorithm 181 The Growing Tree Algorithm 183 Your Turn 186 12. Combining, Dividing . . . . . . . . . . 189 Eller’s Algorithm 189 Implementing Eller’s Algorithm 193 Recursive Division 197 Implementing Recursive Division 199 Your Turn 204 Part IV — Shapes and Surfaces 13. Extending Mazes into Higher Dimensions . . . . . 209 Understanding Dimensions 210 Introducing 3D Mazes 211 Adding a Third Dimension 213 Displaying a 3D Maze 216 Representing Four Dimensions 219 Your Turn 221 14. Bending and Folding Your Mazes . . . . . . . 223 Cylinder Mazes 224 Möbius Mazes 225 Contents • viii Cube Mazes 229 Sphere Mazes 238 Your Turn 246 A1. Summary of Maze Algorithms . . . . . . . . 249 Aldous-Broder 249 Binary Tree 249 Eller’s 250 Growing Tree 251 Hunt-and-Kill 251 Kruskal’s (Randomized) 252 Prim’s (Simplified) 252 Prim’s (True) 253 Recursive Backtracker 253 Recursive Division 254 Sidewinder 254 Wilson’s 255 A2. Comparison of Maze Algorithms . . . . . . . 257 Dead Ends 258 Longest Path 258 Twistiness 259 Directness 260 Intersections 261 Your Turn 262 Index . . . . . . . . . . . . . . 263

Description:
Unlock the secrets to creating random mazes! Whether you're a game developer, an algorithm connoisseur, or simply in search of a new puzzle, you're about to level up. Learn algorithms to randomly generate mazes in a variety of shapes, sizes, and dimensions. Bend them into Moebius strips, fold them i
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.