313 54 21MB
English Pages xxx, 1058 pages: illustrations; 24 cm [1090] Year 2014;2015
Problem Solving with C++
For these Global Editions, the editorial team at Pearson has collaborated with educators across the world to address a wide range of subjects and requirements, equipping students with the best possible learning tools. This Global Edition preserves the cutting-edge approach and pedagogy of the original, but also features alterations, customization, and adaptation from the North American version.
NINTH edition Savitch Mock
This is a special edition of an established title widely used by colleges and universities throughout the world. Pearson published this exclusive edition for the benefit of students outside the United States and Canada. If you purchased this book within the United States or Canada you should be aware that it has been imported without the approval of the Publisher or Author.
Global edition
Global edition
Global edition
Problem Solving with C++ ninth edition
W alter Savitch • Kendrick Mock
Pearson Global Edition
SAVITCH_1292018240_mech.indd 1
20/08/14 7:00 PM
Online Access Thank you for purchasing a new copy of Problem Solving with C++, Ninth Edition, Global Edition. Your textbook includes one year of prepaid access to the book’s Companion Website. This prepaid subscription provides you with full access to the following student support areas: • VideoNotes
• Source Code • Lecture Slides
• Lab Manual
Use a coin to scratch off the coating and reveal your student access code. Do not use a knife or other sharp object as it may damage the code. To access the Problem Solving with C++, Ninth Edition, Global Edition Companion Website for the first time, you will need to register online using a computer with an Internet connection and a web browser. The process takes just a couple of minutes and only needs to be completed once. 1. Go to www.pearsonglobaleditions.com/savitch 2. Click on Companion Website. 3. Click on the Register button. 4. On the registration page, enter your student access code* found beneath the scratch-off panel. Do not type the dashes. You can use lower- or uppercase. 5. Follow the on-screen instructions. If you need help at any time during the online registration process, simply click the Need Help? icon. 6. Once your personal Login Name and Password are confirmed, you can begin using the Problem Solving with C++, Ninth Edition, Global Edition Companion Website! To log in after you have registered: You only need to register for this Companion Website once. After that, you can log in any time at www.pearsonglobaleditions.com/savitch by providing your Login Name and Password when prompted. *Important: The access code can only be used once. This subscription is valid for one year upon activation and is not transferable. If this access code has already been revealed, it may no longer be valid.
SAVITCH_1292018240_ifc.indd 1
22/08/14 6:09 PM
Ninth Edition
Problem Solving
A01_SAVI8249_FM_pp01-30.indd 1
with
C++
18/09/14 4:00 PM
A01_SAVI8249_FM_pp01-30.indd 2
18/09/14 4:00 PM
Ninth Edition Global Edition
Problem Solving
with
C++
Walter Savitch University of California, San Diego
Contributor
Kenrick Mock University of Alaska, Anchorage
GLOBAL EDITION CONTRIBUTORS
Simon Msanjila Mzumbe University, Tanzania
Lupyana Muiche Mzumbe University, Tanzania
Boston Columbus Indianapolis New York San Francisco Upper Saddle River Amsterdam Cape Town Dubai London Madrid Milan Munich Paris Montreal Toronto Delhi Mexico City São Paulo Sydney Hong Kong Seoul Singapore Taipei Tokyo
A01_SAVI8249_FM_pp01-30.indd 3
18/09/14 4:00 PM
Editorial Director: Marcia Horton Acquisitions Editor: Matt Goldstein Program Manager: Kayla Smith-Tarbox Editorial Assistant: Kelsey Loanes Marketing Coordinator: Kathryn Ferranti Production Director: Erin Gregg Managing Editor: Scott Disanno Head, Learning Asset Acquisitions, Global Edition: Laura Dent Acquisition Editor, Global Edition: Subhasree Patra Project Editor, Global Edition: Anuprova Dey Chowdhuri Senior Operations Supervisor: Vincent Scelta
Operations Specialist: Linda Sager Cover Designer: Shree Mohanambal Inbakumar, Lumina Datamatics Permissions Manager: Timothy Nicholls Image Permissions Manager: Karen Sanatar Media Producer: Renata Butera Media Project Manager: Wanda Rockwell Full-Service Vendor: Hardik Popli, Cenveo® Publisher Services Composition: Cenveo Publisher Services Printer/Binder: Courier Westford Cover Printer: Courier Westford
Pearson Education Limited Edinburgh Gate Harlow Essex CM20 2JE England and Associated Companies throughout the world Visit us on the World Wide Web at: www.pearsonglobaleditions.com © Pearson Education Limited 2015 The rights of Walter Savitch and Kendrick Mock to be identified as the authors of this work have been asserted by them in accordance with the Copyright, Designs and Patents Act 1988. Authorized adaptation from the United States edition, entitled Problem Solving with C++, 9th edition, ISBN 978-0-13-359174-3, by Walter Savitch and Kendrick Mock, published by Pearson Education © 2015. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmittedin any form or by any means, electronic, mechanical, photocopying, recording or otherwise, withouteither the prior written permission of the publisher or a license permitting restricted copying in the United Kingdom issued by the Copyright Licensing Agency Ltd, Saffron House, 6–10 Kirby Street, LondonEC1N 8TS. All trademarks used herein are the property of their respective owners. The use of any trademark in this text does not vest in the author or publisher any trademark ownership rights in such trademarks, nor does the use of such trademarks imply any affiliation with or endorsement of this book by such owners. Credits and acknowledgments borrowed from other sources and reproduced, with permission, in this textbook appear below, or on appropriate page within text. Microsoft and/or its respective suppliers make no representations about the suitability of the information contained in the documents and related graphics published as part of the services for any purpose. All such documents and related graphics are provided “as is” without warranty of any kind. Microsoft and/or its respective suppliers hereby disclaim all warranties and conditions with regard to this information, including all warranties and conditions of merchantability, whether express, implied or statutory, fitness for a particular purpose, title and non-infringement. In no event shall Microsoft and/or its respective suppliers be liable for any special, indirect or consequential damages or any damages whatsoever resulting from loss of use, data or profits, whether in an action of contract, negligence or other tortious action, arising out of or in connection with the use or performance of information available from the services. The documents and related graphics contained herein could include technical inaccuracies or typographical errors. Changes are periodically added to the information herein. Microsoft and/or its respective suppliers may make improvements and/or changes in the product(s) and/or the program(s) described herein at any time. Partial screen shots may be viewed in full within the software version specified. Microsoft® and Windows® are registered trademarks of the Microsoft Corporation in the U.S.A. and other countries. This book is not sponsored or endorsed by or affiliated with the Microsoft Corporation. ISBN 10: 1292018240 ISBN 13: 978-1-29-201824-9 10 9 8 7 6 5 4 3 2 1 14 13 12 11 10 British Library Cataloguing-in-Publication Data A catalogue record for this book is available from the British Library Typeset in 10 GiovanniStd-Book by Cenveo Publishing Services Printed and bound by Courier Westford The publisher’s policy is to use paper manufactured from sustainable forests.
A01_SAVI8249_FM_pp01-30.indd 4
29/09/14 6:02 PM
Preface
This book is meant to be used in a first course in programming and computer science using the C++ language. It assumes no previous programming experience and no mathematics beyond high school algebra. If you have used the previous edition of this book, you should read the following section that explains the changes to this ninth edition and then you can skip the rest of this preface. If you are new to this book, the rest of this preface will give you an overview of the book.
Changes to the Ninth Edition This ninth edition presents the same programming philosophy as the eighth edition. All of the material from the eighth edition remains, but with the following enhancements: ■ End-of-chapter programs are now split into Practice Programs and Programming Projects. Practice Programs require a direct application of concepts presented in the chapter and solutions are usually short. Practice Programs are appropriate for laboratory exercises. Programming Projects require additional problem solving and solutions are generally longer than Practice Programs. Programming Projects are appropriate for homework problems. ■ Introduction to C++11 in the context of C++98. Examples of C++11 content includes new integer types, the auto type, raw string literals, strong enumerations, nullptr, ranged for loop, conversion between strings and integers, member initializers, and constructor delegation. ■ Additional material on sorting, secure programming (e.g., overflow, array out of bounds), and inheritance. ■ Correction of errata. ■ Twenty-one new Practice Programs and ten new Programming Projects. ■ Ten new VideoNotes for a total of sixty-four VideoNotes. These VideoNotes walk students through the process of both problem solving and coding to help reinforce key programming concepts. An icon appears in the margin of the book when a VideoNote is available regarding the topic covered in the text. If you are an instructor already using the eighth edition, you can continue to teach your course almost without change.
Flexibility in Topic Ordering This book was written to allow instructors wide latitude in reordering the material. To illustrate this flexibility, we suggest two alternative ways to order
A01_SAVI8249_FM_pp01-30.indd 5
5
18/09/14 4:00 PM
6
Preface
the topics. There is no loss of continuity when the book is read in either of these ways. To ensure this continuity when you rearrange material, you may need to move sections rather than entire chapters. However, only large sections in convenient locations are moved. To help customize a particular order for any class’s needs, the end of this preface contains a dependency chart, and each chapter has a “Prerequisites” section that explains what material needs to be covered before each section in that chapter. Reordering 1: Earlier Classes To effectively design classes, a student needs some basic tools such as control structures and function definitions. This basic material is covered in Chapters 1 through 6. After completing Chapter 6, students can begin to write their own classes. One possible reordering of chapters that allows for such early coverage of classes is the following: Basics: Chapters 1, 2, 3, 4, 5, and 6. This material covers all control structures, function definitions, and basic file I/O. Chapter 3, which covers additional control structures, could be deferred if you wish to cover classes as early as possible. Classes and namespaces: Chapter 10, Sections 11.1 and 11.2 of Chapter 11, and Chapter 12. This material covers defining classes, friends, overloaded operators, and namespaces. Arrays, strings and vectors: Chapters 7 and 8 Pointers and dynamic arrays: Chapter 9 Arrays in classes: Sections 11.3 and 11.4 of Chapter 11 Inheritance: Chapter 15 Recursion: Chapter 14 (Alternately, recursion may be moved to later in the course.) Pointers and linked lists: Chapter 13 Any subset of the following chapters may also be used: Exception handling: Chapter 16 Templates: Chapter 17 Standard Template Library: Chapter 18 Reordering 2: Classes Slightly Later but Still Early This version covers all control structures and the basic material on arrays before doing classes, but classes are covered later than the previous ordering and slightly earlier than the default ordering. Basics: Chapters 1, 2, 3, 4, 5, and 6. This material covers all control structures, function definitions, and the basic file I/O.
A01_SAVI8249_FM_pp01-30.indd 6
18/09/14 4:00 PM
Preface
7
Arrays and strings: Chapter 7, Sections 8.1 and 8.2 of Chapter 8 Classes and namespaces: Chapter 10, Sections 11.1 and 11.2 of Chapter 11, and Chapter 12. This material covers defining classes, friends, overloaded operators, and namespaces. Pointers and dynamic arrays: Chapter 9 Arrays in classes: Sections 11.3 and 11.4 of Chapter 11 Inheritance: Chapter 15 Recursion: Chapter 14. (Alternately, recursion may be moved to later in the course.) Vectors: Chapter 8.3 Pointers and linked lists: Chapter 13 Any subset of the following chapters may also be used: Exception handling: Chapter 16 Templates: Chapter 17 Standard Template Library: Chapter 18
Accessibility to Students It is not enough for a book to present the right topics in the right order. It is not even enough for it to be clear and correct when read by an instructor or other experienced programmer. The material needs to be presented in a way that is accessible to beginning students. In this introductory textbook, I have endeavored to write in a way that students find clear and friendly. Reports from the many students who have used the earlier editions of this book confirm that this style makes the material clear and often even enjoyable to students.
ANSI/ISO C++ Standard This edition is fully compatible with compilers that meet the latest ANSI/ISO C++ standard. At the time of this writing the latest standard is C++11.
Advanced Topics Many “advanced topics” are becoming part of a standard CS1 course. Even if they are not part of a course, it is good to have them available in the text as enrichment material. This book offers a number of advanced topics that can be integrated into a course or left as enrichment topics. It gives thorough coverage of C++ templates, inheritance (including virtual functions), exception handling, and the STL (Standard Template Library). Although this book uses libraries and teaches students the importance of libraries, it does not require any nonstandard libraries. This book uses only libraries that are provided with essentially all C++ implementations.
A01_SAVI8249_FM_pp01-30.indd 7
18/09/14 4:00 PM
8
Preface
Dependency Chart The dependency chart on the next page shows possible orderings of chapters and subsections. A line joining two boxes means that the upper box must be covered before the lower box. Any ordering that is consistent with this partial ordering can be read without loss of continuity. If a box contains a section number or numbers, then the box refers only to those sections and not to the entire chapter.
Summary Boxes Each major point is summarized in a boxed section. These boxed sections are spread throughout each chapter.
Self-Test Exercises Each chapter contains numerous Self-Test Exercises at strategic points. Complete answers for all the Self-Test Exercises are given at the end of each chapter.
VideoNotes VideoNote
A01_SAVI8249_FM_pp01-30.indd 8
VideoNotes are designed for teaching students key programming concepts and techniques. These short step-by-step videos demonstrate how to solve problems from design through coding. VideoNotes allow for self-paced instruction with easy navigation including the ability to select, play, rewind, fast-forward, and stop within each VideoNote exercise.
18/09/14 4:00 PM
9
Preface
DISPLAY P.1 Dependency Chart Chapter 1 Introduction
Chapter 2 C++ Basics
Chapter 4 Functions 1
Chapter 5 Functions 2
Chapter 3 More Flow of Control
Chapter 7 Arrays 7.1–7.3
Chapter 6 I/O Streams
Chapter 14 Recursion
Chapter 10 Classes 1
Chapter 7 7.4 MultiDimensional Arrays
Chapter 11 Classes 2 11.1–11.2
Chapter 8 Strings and Vectors
*Chapter 16 Exception Handling
Chapter 12 Separate Compilation & Namespaces
Chapter 11 11.3 Classes & Arrays
Chapter 9 Pointers and Dynamic Arrays
Chapter 11 11.4 Classes & Dynamic Arrays
Chapter 13 Pointers and Linked Lists
Chapter 15 Inheritance Chapter 17 Templates
*Chapter 16 contains occasional references to derived classes, but those references can be omitted
A01_SAVI8249_FM_pp01-30.indd 9
Chapter 18 STL
18/09/14 4:00 PM
10
Preface
Support Material There is support material available to all users of this book and additional material available only to qualified instructors. Materials Available to All Users of this Book ■ Source
Code from the book ■ PowerPoint slides ■ VideoNotes To access these materials, go to: www.pearsonglobaleditions.com/savitch Resources Available to Qualified Instructors Only Visit Pearson Education’s instructor resource center at www.pearsonglobal editions.com/savitch to access the following instructor resources: ■ Instructor’s Resource Guide—including chapter-by-chapter teaching hints, quiz questions with solutions, and solutions to many programming projects ■ Test Bank and Test Generator ■ PowerPoint Lectures—including programs and art from the text ■ Lab Manual
Integrated Development Environment (IDE) Resource Kits Instructors who adopt this text can order it for students with a kit containing five popular C++ IDEs (Microsoft® Visual Studio 2013 Express Edition, Dev C++, NetBeans, Eclipse, and CodeLite) and access to a Web site containing written and video tutorials for getting started in each IDE. For ordering information, please contact your campus Pearson Education representative.
Contact Us Your comments, suggestions, questions, and corrections are always welcome. Please e-mail them to [email protected]
Acknowledgments Numerous individuals and groups have provided me with suggestions, discussions, and other help in preparing this textbook. Much of the first edition of this book was written while I was visiting the Computer Science Department at the University of Colorado in Boulder. The remainder of the writing on the first edition and the work on subsequent editions was done in the Computer Science and Engineering Department at the University of California, San Diego (UCSD). I am grateful to these institutions for providing a conducive environment for teaching this material and writing this book.
A01_SAVI8249_FM_pp01-30.indd 10
18/09/14 4:00 PM
Preface
11
I extend a special thanks to all the individuals who have contributed critiques or programming projects for this or earlier editions and drafts of this book. In alphabetical order, they are: Alex Feldman, Amber Settle, Andrew Burt, Andrew Haas, Anne Marchant, Barney MacCabe, Bob Holloway, Bob Matthews, Brian R. King, Bruce Johnston, Carol Roberts, Charles Dowling, Claire Bono, Cynthia Martincic, David Feinstein, David Teague, Dennis Heckman, Donald Needham, Doug Cosman, Dung Nguyen, Edward Carr, Eitan M. Gurari, Ethan Munson, Firooz Khosraviyani, Frank Moore, Gilliean Lee, Huzefa Kagdi, James Stepleton, Jeff Roach, Jeffrey Watson, Jennifer Perkins, Jerry Weltman, Joe Faletti, Joel Cohen, John J. Westman, John Marsaglia, John Russo, Joseph Allen, Joseph D. Oldham, Jerrold Grossman, Jesse Morehouse, Karla Chaveau, Ken Rockwood, Larry Johnson, Len Garrett, Linda F. Wilson, Mal Gunasekera, Marianne Lepp, Matt Johnson, Michael Keenan, Michael Main, Michal Sramka, Naomi Shapiro, Nat Martin, Noah Aydin, Nisar Hundewale, Paul J. Kaiser, Paul Kube, Paulo Franca, Richard Borie, Scot Drysdale, Scott Strong, Sheila Foster, Steve Mahaney, Susanne Sherba, Thomas Judson, Walter A. Manrique, Wei Lian Chen, and Wojciech Komornicki. I extend a special thanks to the many instructors who used early editions of this book. Their comments provided some of the most helpful reviewing that the book received. Finally, I thank Kenrick Mock who implemented the changes in this edition. He had the almost impossible task of pleasing me, my editor, and his own sensibilities, and he did a superb job of it. Walter Savitch Pearson Education would like to thank Rosanne Els, Mohit Tahiliani, and Ajith Kumar J. for reviewing the Global Edition.
A01_SAVI8249_FM_pp01-30.indd 11
18/09/14 4:00 PM
A01_SAVI8249_FM_pp01-30.indd 12
18/09/14 4:00 PM
Brief Contents
Chapter 1
Introduction to Computers and C++ Programming 31
Chapter 2
C++ Basics 69
Chapter 3
More Flow of Control 141
Chapter 4
Procedural Abstraction and Functions That Return a Value 211
Chapter 5
Functions for All Subtasks 281
Chapter 6
I/O Streams as an Introduction to Objects and Classes 335
Chapter 7
Arrays 407
Chapter 8
Strings and Vectors 481
Chapter 9
Pointers and Dynamic Arrays 537
Chapter 10 Defining Classes 571 Chapter 11 Friends, Overloaded Operators, and Arrays in Classes 649
13
A01_SAVI8249_FM_pp01-30.indd 13
18/09/14 4:00 PM
14
Brief Contents
Chapter 12 Separate Compilation and Namespaces 733 Chapter 13 Pointers and Linked Lists 769 Chapter 14 Recursion 819 Chapter 15 Inheritance 863 Chapter 16 Exception Handling 923 Chapter 17 Templates 955 Chapter 18 Standard Template Library 987 Appendices 1 2 3 4 5 6
C++ Keywords 1045 Precedence of Operators 1046 The ASCII Character Set 1048 Some Library Functions 1049 Inline Functions 1056 Overloading the Array Index Square Brackets 1057
7 The this Pointer 1059 8 Overloading Operators as Member Operators 1062
Index 1064 Credits 1085
A01_SAVI8249_FM_pp01-30.indd 14
18/09/14 4:00 PM
Contents
Chapter 1 Introduction to Computers and C++ Programming 31 1.1 Computer Systems 32
Hardware 32 Software 37 High-Level Languages 38 Compilers 39 History Note 42 1.2 Programming and Problem-Solving 42
Algorithms 42 Program Design 45 Object-Oriented Programming 46 The Software Life Cycle 47 1.3 Introduction to C++ 48
Origins of the C++ Language 48 A Sample C++ Program 49 Pitfall: Using the Wrong Slash in \n 53 Programming Tip: Input and Output Syntax 53 Layout of a Simple C++ Program 54 Pitfall: Putting a Space Before the include File Name 56 Compiling and Running a C++ Program 56 Pitfall: Compiling a C++11 program 57 Programming Tip: Getting Your Program to Run 57 1.4 Testing and Debugging 59
Kinds of Program Errors 60 Pitfall: Assuming Your Program Is Correct 61
15
A01_SAVI8249_FM_pp01-30.indd 15
18/09/14 4:00 PM
16
Contents
Chapter Summary 62 Answers to Self-Test Exercises 63 Practice Programs 65 Programming Projects 66
Chapter 2
C++ Basics 69
2.1 Variables and Assignments 70
Variables 70 Names: Identifiers 72 Variable Declarations 74 Assignment Statements 75 Pitfall: Uninitialized Variables 77 Programming Tip: Use Meaningful Names 79 2.2 Input and Output 80
Output Using cout 80 Include Directives and Namespaces 82 Escape Sequences 83 Programming Tip: End Each Program with a \n or endl 85 Formatting for Numbers with a Decimal Point 85 Input Using cin 86 Designing Input and Output 88 Programming Tip: Line Breaks in I/O 88 2.3 Data Types and Expressions 90
The Types int and double 90 Other Number Types 92 C++11 Types 93 The Type char 94 The Type bool 96 Introduction to the Class string 96 Type Compatibilities 98 Arithmetic Operators and Expressions 99 Pitfall: Whole Numbers in Division 102 More Assignment Statements 104 2.4 Simple Flow of Control 104
A Simple Branching Mechanism 105 Pitfall: Strings of Inequalities 110 Pitfall: Using = in place of == 111 Compound Statements 112
A01_SAVI8249_FM_pp01-30.indd 16
18/09/14 4:00 PM
Contents
17
Simple Loop Mechanisms 114 Increment and Decrement Operators 117 Programming Example: Charge Card Balance 119 Pitfall: Infinite Loops 120 2.5 Program Style 123
Indenting 123 Comments 123 Naming Constants 125
Chapter Summary 128 Answers to Self-Test Exercises 128 Practice Programs 133 Programming Projects 135
Chapter 3
More Flow of Control 141
3.1 Using Boolean Expressions 142
Evaluating Boolean Expressions 142 Pitfall: Boolean Expressions Convert to int Values 146 Enumeration Types (Optional) 149 3.2 Multiway Branches 150
Nested Statements 150 Programming Tip: Use Braces in Nested Statements 151 Multiway if-else Statements 153 Programming Example: State Income Tax 155 The switch Statement 158 Pitfall: Forgetting a break in a switch Statement 162 Using switch Statements for Menus 163 Blocks 165 Pitfall: Inadvertent Local Variables 168 3.3 More About C++ Loop Statements 169
The while Statements Reviewed 169 Increment and Decrement Operators Revisited 171 The for Statement 174 Pitfall: Extra Semicolon in a for Statement 179 What Kind of Loop to Use 180 Pitfall: Uninitialized Variables and Infinite Loops 182 The break Statement 183 Pitfall: The break Statement in Nested Loops 184
A01_SAVI8249_FM_pp01-30.indd 17
18/09/14 4:00 PM
18
Contents
3.4 Designing Loops 185
Loops for Sums and Products 185 Ending a Loop 187 Nested Loops 190 Debugging Loops 192
Chapter Summary 195 Answers to Self-Test Exercises 196 Practice Programs 202 Programming Projects 204
Chapter 4 Procedural Abstraction and Functions That Return a Value 211 4.1 Top-Down Design 212 4.2 Predefined Functions 213
Using Predefined Functions 213 Random Number Generation 218 Type Casting 220 Older Form of Type Casting 222 Pitfall: Integer Division Drops the Fractional Part 222 4.3 Programmer-Defined Functions 223
Function Definitions 223 Functions That Return a Boolean Value 229 Alternate Form for Function Declarations 229 Pitfall: Arguments in the Wrong Order 230 Function Definition–Syntax Summary 231 More About Placement of Function Definitions 232 Programming Tip: Use Function Calls in Branching Statements 233 4.4 Procedural Abstraction 234
The Black-Box Analogy 234 Programming Tip: Choosing Formal Parameter Names 237 Programming Tip: Nested Loops 238 Case Study: Buying Pizza 241 Programming Tip: Use Pseudocode 247 4.5 Scope and Local Variables 248
The Small Program Analogy 248 Programming Example: Experimental Pea Patch 251
A01_SAVI8249_FM_pp01-30.indd 18
18/09/14 4:00 PM
Contents
19
Global Constants and Global Variables 251 Call-by-Value Formal Parameters Are Local Variables 254 Block Scope 256 Namespaces Revisited 257 Programming Example: The Factorial Function 260 4.6 Overloading Function Names 262
Introduction to Overloading 262 Programming Example: Revised Pizza-Buying Program 265 Automatic Type Conversion 268
Chapter Summary 270 Answers to Self-Test Exercises 270 Practice Programs 275 Programming Projects 277
Chapter 5
Functions for All Subtasks 281
5.1 void Functions 282
Definitions of void Functions 282 Programming Example: Converting Temperatures 285 return Statements in void Functions 285
5.2 Call-By-Reference Parameters 289
A First View of Call-by-Reference 289 Call-by-Reference in Detail 292 Programming Example: The swap_values Function 297 Mixed Parameter Lists 298 Programming Tip: What Kind of Parameter to Use 299 Pitfall: Inadvertent Local Variables 300 5.3 Using Procedural Abstraction 303
Functions Calling Functions 303 Preconditions and Postconditions 305 Case Study: Supermarket Pricing 306 5.4 Testing and Debugging Functions 311
Stubs and Drivers 312 5.5 General Debugging Techniques 317
Keep an Open Mind 317 Check Common Errors 317
A01_SAVI8249_FM_pp01-30.indd 19
18/09/14 4:00 PM
20
Contents
Localize the Error 318 The assert Macro 320
Chapter Summary 322 Answers to Self-Test Exercises 323 Practice Programs 326 Programming Projects 329
Chapter 6 I/O Streams as an Introduction to Objects and Classes 335 6.1 Streams and Basic File I/O 336
Why Use Files for I/O? 337 File I/O 338 Introduction to Classes and Objects 342 Programming Tip: Check Whether a File Was Opened Successfully 344 Techniques for File I/O 346 Appending to a File (Optional) 350 File Names as Input (Optional) 351 6.2 Tools for Stream I/O 353
Formatting Output with Stream Functions 353 Manipulators 359 Streams as Arguments to Functions 362 Programming Tip: Checking for the End of a File 362 A Note on Namespaces 365 Programming Example: Cleaning Up a File Format 366 6.3 Character I/O 368
The Member Functions get and put 368 The putback Member Function (Optional) 372 Programming Example: Checking Input 373 Pitfall: Unexpected '\n' in Input 375 Programming Example: Another new_line Function 377 Default Arguments for Functions (Optional) 378 The eof Member Function 383 Programming Example: Editing a Text File 385 Predefined Character Functions 386 Pitfall: toupper and tolower Return Values 388
A01_SAVI8249_FM_pp01-30.indd 20
18/09/14 4:00 PM
Contents
21
Chapter Summary 390 Answers to Self-Test Exercises 391 Practice Programs 398 Programming Projects 400
Chapter 7
Arrays 407
7.1 Introduction to Arrays 408
Declaring and Referencing Arrays 408 Programming Tip: Use for Loops with Arrays 410 Pitfall: Array Indexes Always Start with Zero 410 Programming Tip: Use a Defined Constant for the Size of an Array 410 Arrays in Memory 412 Pitfall: Array Index Out of Range 413 Initializing Arrays 416 Programming Tip: C++11 Range-Based for Statement 416 7.2 Arrays in Functions 419
Indexed Variables as Function Arguments 419 Entire Arrays as Function Arguments 421 The const Parameter Modifier 424 Pitfall: Inconsistent Use of const Parameters 427 Functions That Return an Array 427 Case Study: Production Graph 428 7.3 Programming with Arrays 441
Partially Filled Arrays 441 Programming Tip: Do Not Skimp on Formal Parameters 444 Programming Example: Searching an Array 444 Programming Example: Sorting an Array 447 Programming Example: Bubble Sort 451 7.4 Multidimensional Arrays 454
Multidimensional Array Basics 455 Multidimensional Array Parameters 455 Programming Example: Two-Dimensional Grading Program 457 Pitfall: Using Commas Between Array Indexes 461
A01_SAVI8249_FM_pp01-30.indd 21
18/09/14 4:00 PM
22
Contents
Chapter Summary 462 Answers to Self-Test Exercises 463 Practice Programs 467 Programming Projects 469
Chapter 8
Strings and Vectors 481
8.1 An Array Type for Strings 483
C-String Values and C-String Variables 483 Pitfall: Using = and == with C Strings 486 Other Functions in 488 Pitfall: Copying past the end of a C-string using strcpy 491 C-String Input and Output 494 C-String-to-Number Conversions and Robust Input 496 8.2 The Standard string Class 502
Introduction to the Standard Class string 502 I/O with the Class string 505 Programming Tip: More Versions of getline 508 Pitfall: Mixing cin >> variable; and getline 509 String Processing with the Class string 510 Programming Example: Palindrome Testing 514 Converting Between string Objects and C Strings 517 Converting Between Strings and Numbers 518 8.3 Vectors 519
Vector Basics 519 Pitfall: Using Square Brackets Beyond the Vector Size 522 Programming Tip: Vector Assignment Is Well Behaved 523 Efficiency Issues 523
Chapter Summary 525 Answers to Self-Test Exercises 525 Practice Programs 527 Programming Projects 528
Chapter 9
Pointers and Dynamic Arrays 537
9.1 Pointers 538
Pointer Variables 539 Basic Memory Management 546
A01_SAVI8249_FM_pp01-30.indd 22
18/09/14 4:00 PM
Contents
23
Pitfall: Dangling Pointers 547 Static Variables and Automatic Variables 548 Programming Tip: Define Pointer Types 548 9.2 Dynamic Arrays 551
Array Variables and Pointer Variables 551 Creating and Using Dynamic Arrays 552 Pointer Arithmetic (Optional) 558 Multidimensional Dynamic Arrays (Optional) 560
Chapter Summary 562 Answers to Self-Test Exercises 562 Practice Programs 563 Programming Projects 564
Chapter 10
Defining Classes 571
10.1 Structures 572
Structures for Diverse Data 572 Pitfall: Forgetting a Semicolon in a Structure Definition 577 Structures as Function Arguments 578 Programming Tip: Use Hierarchical Structures 579 Initializing Structures 581 10.2 Classes 584
Defining Classes and Member Functions 584 Public and Private Members 589 Programming Tip: Make All Member Variables Private 597 Programming Tip: Define Accessor and Mutator Functions 597 Programming Tip: Use the Assignment Operator with Objects 599 Programming Example: BankAccount Class—Version 1 600 Summary of Some Properties of Classes 604 Constructors for Initialization 606 Programming Tip: Always Include a Default Constructor 614 Pitfall: Constructors with No Arguments 615 Member Initializers and Constructor Delegation in C++11 617 10.3 Abstract Data Types 618
Classes to Produce Abstract Data Types 619 Programming Example: Alternative Implementation of a Class 623
A01_SAVI8249_FM_pp01-30.indd 23
18/09/14 4:00 PM
24
Contents
10.4 Introduction to Inheritance 628
Derived Classes 629 Defining Derived Classes 630
Chapter Summary 634 Answers to Self-Test Exercises 635 Practice Programs 641 Programming Projects 642
Chapter 11 Friends, Overloaded Operators, and Arrays in Classes 649 11.1 Friend Functions 650
Programming Example: An Equality Function 650 Friend Functions 654 Programming Tip: Define Both Accessor Functions and Friend Functions 656 Programming Tip: Use Both Member and Nonmember Functions 658 Programming Example: Money Class (Version 1) 658 Implementation of digit_to_int (Optional) 665 Pitfall: Leading Zeros in Number Constants 666 The const Parameter Modifier 668 Pitfall: Inconsistent Use of const 669 11.2 Overloading Operators 673
Overloading Operators 674 Constructors for Automatic Type Conversion 677 Overloading Unary Operators 679 Overloading >> and number) cout