Details

Generic Data Structures and Algorithms in Go


Generic Data Structures and Algorithms in Go

An Applied Approach Using Concurrency, Genericity and Heuristics

von: Richard Wiener

66,99 €

Verlag: Apress
Format: PDF
Veröffentl.: 12.07.2022
ISBN/EAN: 9781484281918
Sprache: englisch
Anzahl Seiten: 520

Dieses eBook enthält ein Wasserzeichen.

Beschreibungen

<div><div>Advance your understanding of generic data structures and algorithms and their applications using Go and the effective use of concurrency. You are invited on a journey that aims to improve your programming and problem-solving skills. This book takes you to the next step by showing how to get your programs to work efficiently as well as correctly.&nbsp;</div><div><br></div><div><div>As you explore many data structures and the algorithms and applications associated with them, you'll focus on the trade-offs&nbsp;between speed and storage and the benefits of deploying concurrency when appropriate. This book will demonstrate the huge increases in application performance that are possible. The presentation of classic data structures and techniques of algorithm design (greedy, divide and conquer, branch-and-bound to name a few) provides an essential foundation and toolkit for problem solving. But this book goes further by presenting heuristic algorithms and their implementations forsolving computationally intractable combinatoric&nbsp;optimization problems such as the travelling salesperson problem.&nbsp;Simulated annealing and genetic algorithms are among the techniques used.</div><div><br></div></div><div>The consistent style of coding used throughout this book exploits Go’s ability to implement abstract, generic and constrained generic data types without the use of classes.&nbsp;&nbsp;Although some familiarity with Go is assumed, this book should advance your ability to use Go to tackle server-side applications, games, machine learning, information retrieval and other application domains where speed and storage efficiency is essential.</div></div><div><br></div><div><b>What You'll Learn</b></div><div><ul><li>Explore classical data structures and algorithms aimed at making your applications run faster or require less storage</li><li>Use the new generic features of Go to build reusable data structures</li><li>Utilize concurrency for maximizing application performance</li><li>See the power of heuristic algorithms for computationally intractable problems</li><li>Enhance and improve your Go programming skills</li></ul></div><div><b>Who This Book Is For</b></div><div><br></div>Practicing Go software developers and students who wish to advance their programming and problem-solving skills and experience the excitement and see the benefits of using generic data structures and algorithms that utilize concurrency whenever possible.<br>
1. A Tour Of Generics and Concurrency In Go.- 2. Algorithm Efficiency – Sorting and Searching.- 3. Abstract Data Types: OOP Without Classes in Go.- 4. ADT In Action: Game Of Life.- 5. Stacks.- 6. Queues and Lists.- 7. Hash Tables.- 8. Binary Trees.- 9. Binary Search Tree.- 10. AVL Trees.- 11. Heap Trees.- 12. Red Black Trees.- 13. Expression Trees.- 14. Ecological Simulation With Concurrency.- 15. Dynamic Programming.- 16. Graph Structures.- 17. Travelling Salesperson Problem.- 18. Branch and Bound Solution to TSP.- 19. Simulated Annealing Heuristic Solution to TSP.- 20. Genetic Algorithm for TSP.- 21.&nbsp;Neural Networks and Machine Learning.
<b>Richard Wiener, Ph.D.</b> authored or co-authored 22 professional, software development and computer-science textbooks published by Wiley, Addison-Wesley, Prentice-Hall, Cambridge University Press and Thompson.&nbsp; Served as founding Editor-in-Chief of the Journal of Object-Oriented Programming for 12 years and later, founding Editor-in-Chief of the Journal of Object Technology for 9 years.&nbsp; Worked as Associate Professor of Computer Science at the University of Colorado, Colorado Springs (UCCS) from 1977-2012.&nbsp; Served as Department Chair during last four years at UCCS. Served as consultant and software developer for IBM, HP, Boeing, Textronix, DEC and many other companies.&nbsp; Presented industry short-courses all over the world from 1980 to 2006. Earned BS and MS in Electrical Engineering from City University of New York and Ph.D. from Polytechnic Institute of New York.<br>
<div><div>Advance your understanding of generic data structures and algorithms and their applications using Go and the effective use of concurrency. You are invited on a journey that aims to improve your programming and problem-solving skills. This book takes you to the next step by showing how to get your programs to work efficiently as well as correctly.&nbsp;</div><div><br></div><div>As you explore many data structures and the algorithms and applications associated with them, you'll focus on the trade-offs&nbsp;between speed and storage and the benefits of deploying concurrency when appropriate. This book will demonstrate the huge increases in application performance that are possible. The presentation of classic data structures and techniques of algorithm design (greedy, divide and conquer, branch-and-bound to name a few) provides an essential foundation and toolkit for problem solving. But this book goes further by presenting heuristic algorithms and their implementations for solving computationally intractable combinatoric&nbsp;optimization problems such as the travelling salesperson problem.&nbsp;Simulated annealing and genetic algorithms are among the techniques used.</div><div><br></div><div>The consistent style of coding used throughout this book exploits Go’s ability to implement abstract, generic and constrained generic data types without the use of classes.&nbsp;&nbsp;Although some familiarity with Go is assumed, this book should advance your ability to use Go to tackle server-side applications, games, machine learning, information retrieval and other application domains where speed and storage efficiency is essential.</div></div><div><br></div><div>You will:</div><div><ul><li>Explore classical data structures and algorithms aimed at making your applications run faster or require less storage</li><li>Use the new generic features of Go to build reusable data structures</li><li>Utilize concurrency for maximizing application performance</li><li>See the power of heuristic algorithms for computationally intractable problems</li><li>Enhance and improve your Go programming skills</li></ul></div>
Uniquely covers generics-based data structures and algorithms in Golang Features the use of concurrency using go-routines whenever possible and appropriate Presents heuristic algorithm design in solving computationally hard problems such as combinatoric optimization

Diese Produkte könnten Sie auch interessieren:

Software Process Modeling
Software Process Modeling
von: Silvia T. Acuna, Natalia Juristo
PDF ebook
96,29 €
A Software Process Model Handbook for Incorporating People's Capabilities
A Software Process Model Handbook for Incorporating People's Capabilities
von: Silvia T. Acuna, Natalia Juristo, Ana Maria Moreno, Alicia Mon
PDF ebook
149,79 €
XML for Bioinformatics
XML for Bioinformatics
von: Ethan Cerami
PDF ebook
53,49 €