Introduction to Java Programming and Data Structures, 12th edition
Published by Pearson Prentice Hall (December 4, 2019) © 2020
- Y Daniel Liang Georgia Southern University
eTextbook
- Anytime, anywhere learning with the Pearson+ app
- Easy-to-use search, navigation and notebook
- Simpler studying with flashcards
- Hardcover, paperback or looseleaf edition
- Affordable rental option for select titles
For courses in Java programming.
Seamlessly integrates programming, data structures and algorithms in 1 text
With a fundamentals-first approach, Introduction to Java Programming and Data Structures, Comprehensive Version builds a strong foundation of basic programming concepts and techniques before teaching object-oriented programming and advanced Java programming. Liang explains programming in a problem-driven way that focuses on problem solving rather than syntax, illustrating basic concepts by example and providing many exercises with various levels of difficulty for students to practice.
The 12th Edition is completely revised in every detail to enhance clarity, presentation, content, examples and exercises.
Hallmark features of this title
- Check Points provide review questions to help students track their progress as they read through the chapter and evaluate their learning.
- The Chapter Summary reviews the important subjects that students should understand and remember. It helps them reinforce the key concepts they have learned in the chapter.
- Notes, Tips, Cautions and Design Guides are inserted throughout the text to offer valuable advice and insight on important aspects of program development.
- Problems and Case Studies teach problem-solving and programming concepts. The book uses many small, simple and stimulating examples to demonstrate important ideas.
- Quizzes are accessible online and grouped by sections for students to self-test programming concepts and techniques.
New and updated features of this title
- NEW: Both Comparable and Comparator are used to compare elements in Heap, Priority-Queue, BST, and AVLTree. This is consistent with the Java API and is more useful and flexible.
- NEW: String matching algorithms are introduced in Chapter 22: Developing Efficient Algorithms.
- UPDATED: Java 9, 10, 11 and FX11 are covered to keep the text up to date with current technologies. Examples are improved and simplified.
- UPDATED: Lambda expressions are used in more examples and exercises in the data structures chapters to simplify coding.
- UPDATED: Programming Exercises are grouped by sections to provide students with opportunities to apply the new skills they have learned on their own.
- Additionally, more than 200 programming exercises with solutions, including several newly added exercises, are provided to the instructors on the Instructor Resource Website. These exercises are not printed in the text.
- Introduction to Computers, Programs, and Javaâ„¢
- Elementary Programming
- Selections
- Mathematical Functions, Characters, and Strings
- Loops
- Methods
- Single-Dimensional Arrays
- Multidimensional Arrays
- Objects and Classes
- Object-Oriented Thinking
- Inheritance and Polymorphism
- Exception Handling and Text I/O
- Abstract Classes and Interfaces
- JavaFX Basics
- Event-Driven Programming and Animations
- JavaFX UI Controls and Multimedia
- Binary I/O
- Recursion
- Generics
- Lists, Stacks, Queues, and Priority Queues
- Sets and Maps
- Developing Efficient Algorithms
- Sorting
- Implementing Lists, Stacks, Queues, and Priority Queues
- Binary Search Trees
- AVL Trees
- Hashing
- Graphs and Applications
- Weighted Graphs and Applications
- Aggregate Operations for Collection Streams
- Bonus Chapters 31–44 are available from the Companion Website at www.pearsonhighered.com/liang:
- Advanced JavaFX and FXML
- Multithreading and Parallel Programming
- Networking
- Java Database Programming
- Advanced Database Programming
- Internationalization
- Servlets
- JavaServer Pages
- JavaServer Faces
- RMI
- Web Services
- 2-4 Trees and B-Trees
- Red-Black Trees
- Testing Using JUnit
APPENDICES
- A. Java Keywords and Reserved Words
- B. The ASCII Character Set
- C. Operator Precedence Chart
- D. Java Modifiers
- E. Special Floating-Point Values
- F. Number Systems
- G. Bitwise Operations
- H. Regular Expressions
- I. Enumerated Types
- J. The Big-O, Big-Omega, and Big-Theta Notations
About our author
Dr. Liang earned his Ph.D. in Computer Science from the University of Oklahoma in 1991, and his M.S. and B.S. in Computer Science from Fudan University in Shanghai, China in 1986 and 1983. Prior to joining Armstrong State University (now merged with Georgia Southern University), he was an Associate Professor in computer science at Purdue University in Fort Wayne, Indiana, where he twice received the Excellence in Research award.
Dr. Liang is currently a Professor of Computer Science at Georgia Southern University. He was trained in theoretical computer science. He has published in the SIAM Journal on Computing, Discrete Applied Mathematics, Acta Informatics and Information Processing Letters. He is the author of more than 30 books. His popular computer science texts are widely used in the world.
Dr. Liang was elected a Java Champion by Sun Microsystems (now Oracle) in 2005. He has given lectures on programming internationally.
Need help? Get in touch