13%
Elements of Programming

Elements of Programming

          
5
4
3
2
1

Out of Stock


Premium quality
Premium quality
Bookswagon upholds the quality by delivering untarnished books. Quality, services and satisfaction are everything for us!
Easy Return
Easy return
Not satisfied with this product! Keep it in original condition and packaging to avail easy return policy.
Certified product
Certified product
First impression is the last impression! Address the book’s certification page, ISBN, publisher’s name, copyright page and print quality.
Secure Checkout
Secure checkout
Security at its finest! Login, browse, purchase and pay, every step is safe and secured.
Money back guarantee
Money-back guarantee:
It’s all about customers! For any kind of bad experience with the product, get your actual amount back after returning the product.
On time delivery
On-time delivery
At your doorstep on time! Get this book delivered without any delay.
Notify me when this book is in stock
Add to Wishlist

About the Book

“Ask a mechanical, structural, or electrical engineer how far they would get without a heavy reliance on a firm mathematical foundation, and they will tell you, ‘not far.’ Yet so-called software engineers often practice their art with little or no idea of the mathematical underpinnings of what they are doing. And then we wonder why software is notorious for being delivered late and full of bugs, while other engineers routinely deliver finished bridges, automobiles, electrical appliances, etc., on time and with only minor defects. This book sets out to redress this imbalance. Members of my advanced development team at Adobe who took the course based on the same material all benefited greatly from the time invested. It may appear as a highly technical text intended only for computer scientists, but it should be required reading for all practicing software engineers.”     —Martin Newell, Adobe Fellow  “The book contains some of the most beautiful code I have ever seen.”     —Bjarne Stroustrup, Designer of C++ “I am happy to see the content of Alex’s course, the development and teaching of which I strongly supported as the CTO of Silicon Graphics, now available to all programmers in this elegant little book.”     —Forest Baskett, General Partner, New Enterprise Associates “Paul’s patience and architectural experience helped to organize Alex’s  mathematical approach into a tightly-structured edifice—an impressive feat!”     —Robert W. Taylor, Founder of Xerox PARC CSL and DEC Systems Research Center Elements of Programming provides a different understanding of programming than is presented elsewhere. Its major premise is that practical programming, like other areas of science and engineering,must be based on a solid mathematical foundation. The book shows that algorithms implemented in a real programming language, such as C++, can operate in the most general mathematical setting. For example, the fast exponentiation  algorithm is defined to work with any associative operation. Using abstract algorithms leads to efficient, reliable, secure, and economical software. This is not an easy book. Nor is it a compilation of tips and tricks for incremental improvements in your programming skills. The book’s value is more fundamental and, ultimately, more critical for insight into programming. To benefit fully, you will need to work through it from beginning to end, reading the code, proving the lemmas, and doing the exercises. When finished, you will see how the application of the deductive method to your programs assures that your system’s software components will work together and behave as they must. The book presents a number of algorithms and requirements for types on which they are defined. The code for these descriptions—also available on the Web—is written in a small subset of C++ meant to be accessible to any experienced programmer. This subset is defined in a special language appendix coauthored by Sean Parent and Bjarne Stroustrup. Whether you are a software developer, or any other professional for whom programming is an important activity, or a committed student, you will come to understand what the book’s experienced authors have been teaching and demonstrating for years—that mathematics is good for programming, and that theory is good for practice.

Table of Contents:
Preface     ix About the Authors     xiii Chapter 1: Foundations     1 1.1 Categories of Ideas: Entity, Species, Genus 1 1.2 Values 2 1.3 Objects 4 1.4 Procedures 6 1.5 Regular Types 6 1.6 Regular Procedures 8 1.7 Concepts 10 1.8 Conclusions 14 Chapter 2: Transformations and Their Orbits     15 2.1 Transformations 15 2.2 Orbits 18 2.3 Collision Point 21 2.4 Measuring Orbit Sizes 27 2.5 Actions 28 2.6 Conclusions 29 Chapter 3: Associative Operations     31 3.1 Associativity 31 3.2 Computing Powers 33 3.3 Program Transformations 35 3.4 Special-Case Procedures 39 3.5 Parameterizing Algorithms 42 3.6 Linear Recurrences 43 3.7 Accumulation Procedures 46 3.8 Conclusions 47 Chapter 4: Linear Orderings     49 4.1 Classification of Relations 49 4.2 Total and Weak Orderings 51 4.3 Order Selection 52 4.4 Natural Total Ordering 61 4.5 Clusters of Derived Procedures 62 4.6 Extending Order-Selection Procedures 63 4.7 Conclusions 63 Chapter 5: Ordered Algebraic Structures     65 5.1   Basic Algebraic Structures 65 5.2   Ordered Algebraic Structures 70 5.3   Remainder 71 5.4   Greatest Common Divisor 76 5.5   Generalizing gcd 79 5.6   Stein gcd 81 5.7   Quotient 81 5.8   Quotient and Remainder for Negative Quantities 83 5.9   Concepts and Their Models 85 5.10 Computer Integer Types 87 5.11 Conclusions 88 Chapter 6: Iterators     89 6.1   Readability 89 6.2   Iterators 90 6.3   Ranges 92 6.4   Readable Ranges 95 6.5   Increasing Ranges 103 6.6   Forward Iterators 106 6.7   Indexed Iterators 110 6.8   Bidirectional Iterators 111 6.9   Random-Access Iterators 113 6.10 Conclusions 114 Chapter 7: Coordinate Structures     115 7.1 Bifurcate Coordinates 115 7.2 Bidirectional Bifurcate Coordinates 119 7.3 Coordinate Structures 124 7.4 Isomorphism, Equivalence, and Ordering 124 7.5 Conclusions 131 Chapter 8: Coordinates with Mutable Successors      133 8.1 Linked Iterators 133 8.2 Link Rearrangements 134 8.3 Applications of Link Rearrangements 140 8.4 Linked Bifurcate Coordinates 143 8.5 Conclusions 148 Chapter 9: Copying      149 9.1 Writability 149 9.2 Position-Based Copying 151 9.3 Predicate-Based Copying 157 9.4 Swapping Ranges 164 9.5 Conclusions 168 Chapter 10: Rearrangements      169 10.1 Permutations 169 10.2 Rearrangements 172 10.3 Reverse Algorithms 174 10.4 Rotate Algorithms 178 10.5 Algorithm Selection 186 10.6 Conclusions 189 Chapter 11: Partition and Merging      191 11.1 Partition 191 11.2 Balanced Reduction 198 11.3 Merging 202 11.4 Conclusions 208 Chapter 12: Composite Objects     209 12.1 Simple Composite Objects 209 12.2 Dynamic Sequences 216 12.3 Underlying Type 222 12.4 Conclusions 225 Afterword 227 Appendix A: Mathematical Notation     231 Appendix B: Programming Language     233 B.1 Language Definition 233 B.2 Macros and Trait Structures 240 Bibliography 243 Index 247


Best Sellers


Product Details
  • ISBN-13: 9780321635372
  • Publisher: Pearson Education (US)
  • Publisher Imprint: Addison-Wesley Educational Publishers Inc
  • Depth: 25
  • Height: 238 mm
  • No of Pages: 288
  • Series Title: English
  • Weight: 570 gr
  • ISBN-10: 032163537X
  • Publisher Date: 25 Jun 2009
  • Binding: Hardback
  • Edition: 1
  • Language: English
  • Returnable: N
  • Spine Width: 22 mm
  • Width: 169 mm


Similar Products

How would you rate your experience shopping for books on Bookswagon?

Add Photo
Add Photo

Customer Reviews

REVIEWS           
Click Here To Be The First to Review this Product
Elements of Programming
Pearson Education (US) -
Elements of Programming
Writing guidlines
We want to publish your review, so please:
  • keep your review on the product. Review's that defame author's character will be rejected.
  • Keep your review focused on the product.
  • Avoid writing about customer service. contact us instead if you have issue requiring immediate attention.
  • Refrain from mentioning competitors or the specific price you paid for the product.
  • Do not include any personally identifiable information, such as full names.

Elements of Programming

Required fields are marked with *

Review Title*
Review
    Add Photo Add up to 6 photos
    Would you recommend this product to a friend?
    Tag this Book
    Read more
    Does your review contain spoilers?
    What type of reader best describes you?
    I agree to the terms & conditions
    You may receive emails regarding this submission. Any emails will include the ability to opt-out of future communications.

    CUSTOMER RATINGS AND REVIEWS AND QUESTIONS AND ANSWERS TERMS OF USE

    These Terms of Use govern your conduct associated with the Customer Ratings and Reviews and/or Questions and Answers service offered by Bookswagon (the "CRR Service").


    By submitting any content to Bookswagon, you guarantee that:
    • You are the sole author and owner of the intellectual property rights in the content;
    • All "moral rights" that you may have in such content have been voluntarily waived by you;
    • All content that you post is accurate;
    • You are at least 13 years old;
    • Use of the content you supply does not violate these Terms of Use and will not cause injury to any person or entity.
    You further agree that you may not submit any content:
    • That is known by you to be false, inaccurate or misleading;
    • That infringes any third party's copyright, patent, trademark, trade secret or other proprietary rights or rights of publicity or privacy;
    • That violates any law, statute, ordinance or regulation (including, but not limited to, those governing, consumer protection, unfair competition, anti-discrimination or false advertising);
    • That is, or may reasonably be considered to be, defamatory, libelous, hateful, racially or religiously biased or offensive, unlawfully threatening or unlawfully harassing to any individual, partnership or corporation;
    • For which you were compensated or granted any consideration by any unapproved third party;
    • That includes any information that references other websites, addresses, email addresses, contact information or phone numbers;
    • That contains any computer viruses, worms or other potentially damaging computer programs or files.
    You agree to indemnify and hold Bookswagon (and its officers, directors, agents, subsidiaries, joint ventures, employees and third-party service providers, including but not limited to Bazaarvoice, Inc.), harmless from all claims, demands, and damages (actual and consequential) of every kind and nature, known and unknown including reasonable attorneys' fees, arising out of a breach of your representations and warranties set forth above, or your violation of any law or the rights of a third party.


    For any content that you submit, you grant Bookswagon a perpetual, irrevocable, royalty-free, transferable right and license to use, copy, modify, delete in its entirety, adapt, publish, translate, create derivative works from and/or sell, transfer, and/or distribute such content and/or incorporate such content into any form, medium or technology throughout the world without compensation to you. Additionally,  Bookswagon may transfer or share any personal information that you submit with its third-party service providers, including but not limited to Bazaarvoice, Inc. in accordance with  Privacy Policy


    All content that you submit may be used at Bookswagon's sole discretion. Bookswagon reserves the right to change, condense, withhold publication, remove or delete any content on Bookswagon's website that Bookswagon deems, in its sole discretion, to violate the content guidelines or any other provision of these Terms of Use.  Bookswagon does not guarantee that you will have any recourse through Bookswagon to edit or delete any content you have submitted. Ratings and written comments are generally posted within two to four business days. However, Bookswagon reserves the right to remove or to refuse to post any submission to the extent authorized by law. You acknowledge that you, not Bookswagon, are responsible for the contents of your submission. None of the content that you submit shall be subject to any obligation of confidence on the part of Bookswagon, its agents, subsidiaries, affiliates, partners or third party service providers (including but not limited to Bazaarvoice, Inc.)and their respective directors, officers and employees.

    Accept

    New Arrivals


    Inspired by your browsing history


    Your review has been submitted!

    You've already reviewed this product!
    ASK VIDYA