Languages and Machines: An Introduction to the Theory of Computer Science / Edition 3 available in Hardcover, Paperback
Languages and Machines: An Introduction to the Theory of Computer Science / Edition 3
Languages and Machines: An Introduction to the Theory of Computer Science / Edition 3
Buy New
$166.65Buy Used
$116.83-
SHIP THIS ITEM— This Item is Not Available
-
PICK UP IN STORECheck Availability at Nearby Stores
Available within 2 business hours
This Item is Not Available
-
SHIP THIS ITEM
Temporarily Out of Stock Online
Please check back later for updated availability.
This Item is Not Available
Overview
No special mathematical prerequisites are assumed; the theoretical concepts and associated mathematics are made accessible by a 'learn as you go' approach that develops an intuitive understanding of the concepts through numerous examples and illustrations. Languages & Machines examines the languages of the Chomsky hierarchy, the grammars that generate them, and the finite automata that accept them. Sections on the Church-Turing thesis and computability theory further examine the development of abstract machines. Computational complexity and NP-completeness are introduced by analyzing the computations of Turing machines. Parsing with LL and LR grammars is included to emphasize language definition and to provide the groundwork for the study of compiler design.
Features
- A winning writing style, Languages and Machines is becoming recognized as an instructor's boon
- Effective examples that convey challenging and complex theoretical concepts
- Numerous diagrams illustrating pictorially the underlying concepts
- Step-by-step, unhurried proofs
- A "learn as you go" approach that develops mathematical sophistication
Features New to this Edition:
- DFA minimization
- Rice's Theorem
- Increased coverage of computational complexity
- Additional examples throughout
- Over 150 additional exercises
** Instructor's materials are available from your sales rep. If you do not know your local sales representative, please call 1-800-552-2499 for assistance, or use the Addison Wesley Longman rep-locator at http://hepg.awl.com/rep-locator.
Product Details
ISBN-13: | 2900321322219 |
---|---|
Publisher: | Pearson |
Publication date: | 02/28/2005 |
Edition description: | REV |
Pages: | 672 |
Product dimensions: | 6.00(w) x 1.25(h) x 9.00(d) |
About the Author
About Thomas Sudkamp
Thomas A. Sudkamp holds a Ph.D. in mathematics from the University of Notre Dame and worked extensively in industry and for the Air Force before joining the faculty at Wright State University where he has taught for over 10 years.
Table of Contents
Introduction.I. FOUNDATIONS.
1. Mathematical Preliminaries.Cartesian Product, Relations, and Functions.
Equivalence Relations.
Countable and Uncountable Sets.
Recursive Definitions.
Mathematical Induction.
Directed Graphs.
Exercises.
Bibliographic Notes.
2. Languages.
Finite Specification of Languages.
Regular Sets and Expressions.
Exercises.
Bibliographic Notes.
II. CONTEXT-FREE GRAMMARS AND PARSING.
3. Context-Free Grammars.
Examples of Grammars and Languages.
Regular Grammars.
Grammars and Languages Revisited.
A Context-Free Grammar for Pascal.
Arithmetic Expressions.
Exercises.
Bibliographic Notes.
4. Parsing: An Introduction.
The Graph of a Grammar.
A Breadth-First Top-Down Parser.
A Depth-First Top-Down Parser.
Bottom-Up Parsing.
A Shift-Reduce Parser.
Exercises.
Bibliographic Notes.
5. Normal Forms.
Elimination of Chain Rules.
Useless Symbols.
Chomsky Normal Form.
Removal of Direct Left Recursion.
Greibach Normal Form.
Exercises.
Bibliographic Notes.
III. AUTOMATA AND LANGUAGES.
6. Finite Automata.
Deterministic Finite Automata.
State Diagrams and Examples.
Nondeterministic Finite Automata.
Lambda Transitions.
Removing Nondeterminism.
DFA Minimization.
Exercises.
Bibliographic Notes.
7. Regular Languages and Sets.
Expression Graphs.
Regular Grammars & Finite Automata.
Closure Properties of Regular Languages.
A Nonregular Language.
The Pumping Lemma for Regular Languages.
Myhill-Nerode Theorem.
Exercises.
Bibliographic Notes.
8. Pushdown Automata and Context-Free Languages.
Pushdown Automaton and Context-Free Languages.
The Pumping Lemma for Context-Free Languages.
Closure Properties of Context-Free Languages.
A Two-Stack Automation.
Exercises.
Bibliographic Notes.
9. Turing Machines.
Turing Machines as Language Acceptors.
Alternate Acceptance Criteria.
Multitrack Machines.
Two-Way Tape.
Multitape Machines.
Nondeterministic Turing Machines.
Turing Machines as Language Enumerators.
Exercises.
Bibliographic Notes.
10. The Chomsky Hierarchy.
Context-Sensitive Grammars.
Linear-Bounded Automata.
The Chomsky Hierarchy.
Exercises.
Bibliographic Notes.
IV. DECIDABILITY AND COMPUTABLITY.
11. Decidability.
The Church-Turing Thesis.
The Halting Problem for Turing Machines.
A Universal Machine.
Reducibility.
Rice's Theorem.
An Unsolvable Word Problem.
The Post Correspondence Problem.
Undecidable Problems in Context- Free Grammars.
Exercises.
Bibliographic Notes.
12. Numeric Computation.
Sequential Operation of Turing Machines.
Composition of Functions.
Toward a Programming Languages.
Exercises.
Bibliographic Notes.
13. Mu-Recursive Functions.
Some Primitive Recursive Functions.
Bounded Operators.
Division Functions.
Gödel Numbering and Course-of-Values Recursion.
Computable Partial Functions.
Turing Computability and Mu-Recursive Functions.
The Church-Turing Thesis Revisited.
Exercises.
Bibliographic Notes.
V. COMPUTATIONAL COMPLEXITY.
14. Computational Complexity.
Linear Speed-Up.
Rates of Growth.
Complexity and Turing Machine Variations.
Variations of Time Complexity.
Nondeterministic Complexity.
Space Complexity.
Exercises.
Bibliographic Notes.
15. Tractability and NP-Complete Problems.
The Class NP.
P=NP.
The Satisfiability Problem.
Additional NP-Complete Problems.
Derivative Complexity Classes.
Exercises.
Bibliographic Notes.
VI. DETERMINISTIC PARSING.
16. LL (k) Grammars.
FIRST, FOLLOW, and Lookahead Sets.
Strong LL (k) Grammars.
Construction of FIRSTk Sets.
Construction of FOLLOWk Sets.
A Strong LL(1) Grammar.
A Strong LL(k) Parser.
LL(k) Grammars.
Exercises.
Bibliographic Notes.
17. LR(k) Grammars.
LR(0) Parser.
LR(0) Machine.
Acceptance by the LR(0) Machine.
Acceptance by the LR(p) Machine.
LR(1) Grammars.
Exercises.
Bibliographic Notes.