Categories
Ebooks
-
Business and economy
- Bitcoin
- Businesswoman
- Coaching
- Controlling
- E-business
- Economy
- Finances
- Stocks and investments
- Personal competence
- Computer in the office
- Communication and negotiation
- Small company
- Marketing
- Motivation
- Multimedia trainings
- Real estate
- Persuasion and NLP
- Taxes
- Social policy
- Guides
- Presentations
- Leadership
- Public Relation
- Reports, analyses
- Secret
- Social Media
- Sales
- Start-up
- Your career
- Management
- Project management
- Human Resources
-
For children
-
For youth
-
Education
-
Encyclopedias, dictionaries
-
E-press
- Architektura i wnętrza
- Biznes i Ekonomia
- Home and garden
- E-business
- Finances
- Personal finance
- Business
- Photography
- Computer science
- HR & Payroll
- Computers, Excel
- Accounts
- Culture and literature
- Scientific and academic
- Environmental protection
- Opinion-forming
- Education
- Taxes
- Travelling
- Psychology
- Religion
- Agriculture
- Book and press market
- Transport and Spedition
- Healthand beauty
-
History
-
Computer science
- Office applications
- Data bases
- Bioinformatics
- IT business
- CAD/CAM
- Digital Lifestyle
- DTP
- Electronics
- Digital photography
- Computer graphics
- Games
- Hacking
- Hardware
- IT w ekonomii
- Scientific software package
- School textbooks
- Computer basics
- Programming
- Mobile programming
- Internet servers
- Computer networks
- Start-up
- Operational systems
- Artificial intelligence
- Technology for children
- Webmastering
-
Other
-
Foreign languages
-
Culture and art
-
School reading books
-
Literature
- Antology
- Ballade
- Biographies and autobiographies
- For adults
- Dramas
- Diaries, memoirs, letters
- Epic, epopee
- Essay
- Fantasy and science fiction
- Feuilletons
- Work of fiction
- Humour and satire
- Other
- Classical
- Crime fiction
- Non-fiction
- Fiction
- Mity i legendy
- Nobelists
- Novellas
- Moral
- Okultyzm i magia
- Short stories
- Memoirs
- Travelling
- Narrative poetry
- Poetry
- Politics
- Popular science
- Novel
- Historical novel
- Prose
- Adventure
- Journalism, publicism
- Reportage novels
- Romans i literatura obyczajowa
- Sensational
- Thriller, Horror
- Interviews and memoirs
-
Natural sciences
-
Social sciences
-
School textbooks
-
Popular science and academic
- Archeology
- Bibliotekoznawstwo
- Cinema studies
- Philology
- Polish philology
- Philosophy
- Finanse i bankowość
- Geography
- Economy
- Trade. World economy
- History and archeology
- History of art and architecture
- Cultural studies
- Linguistics
- Literary studies
- Logistics
- Maths
- Medicine
- Humanities
- Pedagogy
- Educational aids
- Popular science
- Other
- Psychology
- Sociology
- Theatre studies
- Theology
- Economic theories and teachings
- Transport i spedycja
- Physical education
- Zarządzanie i marketing
-
Guides
-
Game guides
-
Professional and specialist guides
-
Law
- Health and Safety
- History
- Road Code. Driving license
- Law studies
- Healthcare
- General. Compendium of knowledge
- Academic textbooks
- Other
- Construction and local law
- Civil law
- Financial law
- Economic law
- Economic and trade law
- Criminal law
- Criminal law. Criminal offenses. Criminology
- International law
- International law
- Health care law
- Educational law
- Tax law
- Labor and social security law
- Public, constitutional and administrative law
- Family and Guardianship Code
- agricultural law
- Social law, labour law
- European Union law
- Industry
- Agricultural and environmental
- Dictionaries and encyclopedia
- Public procurement
- Management
-
Tourist guides and travel
- Africa
- Albums
- Southern America
- North and Central America
- Australia, New Zealand, Oceania
- Austria
- Asia
- Balkans
- Middle East
- Bulgary
- China
- Croatia
- The Czech Republic
- Denmark
- Egipt
- Estonia
- Europe
- France
- Mountains
- Greece
- Spain
- Holand
- Iceland
- Lithuania
- Latvia
- Mapy, Plany miast, Atlasy
- Mini travel guides
- Germany
- Norway
- Active travelling
- Poland
- Portugal
- Other
- Russia
- Romania
- Slovakia
- Slovenia
- Switzerland
- Sweden
- World
- Turkey
- Ukraine
- Hungary
- Great Britain
- Italy
-
Psychology
- Philosophy of life
- Kompetencje psychospołeczne
- Interpersonal communication
- Mindfulness
- General
- Persuasion and NLP
- Academic psychology
- Psychology of soul and mind
- Work psychology
- Relacje i związki
- Parenting and children psychology
- Problem solving
- Intellectual growth
- Secret
- Sexapeal
- Seduction
- Appearance and image
- Philosophy of life
-
Religion
-
Sport, fitness, diets
-
Technology and mechanics
Audiobooks
-
Business and economy
- Bitcoin
- Businesswoman
- Coaching
- Controlling
- E-business
- Economy
- Finances
- Stocks and investments
- Personal competence
- Communication and negotiation
- Small company
- Marketing
- Motivation
- Real estate
- Persuasion and NLP
- Taxes
- Guides
- Presentations
- Leadership
- Public Relation
- Secret
- Social Media
- Sales
- Start-up
- Your career
- Management
- Project management
- Human Resources
-
For children
-
For youth
-
Education
-
Encyclopedias, dictionaries
-
History
-
Computer science
-
Other
-
Foreign languages
-
Culture and art
-
School reading books
-
Literature
- Antology
- Ballade
- Biographies and autobiographies
- For adults
- Dramas
- Diaries, memoirs, letters
- Epic, epopee
- Essay
- Fantasy and science fiction
- Feuilletons
- Work of fiction
- Humour and satire
- Other
- Classical
- Crime fiction
- Non-fiction
- Fiction
- Mity i legendy
- Nobelists
- Novellas
- Moral
- Okultyzm i magia
- Short stories
- Memoirs
- Travelling
- Poetry
- Politics
- Popular science
- Novel
- Historical novel
- Prose
- Adventure
- Journalism, publicism
- Reportage novels
- Romans i literatura obyczajowa
- Sensational
- Thriller, Horror
- Interviews and memoirs
-
Natural sciences
-
Social sciences
-
Popular science and academic
-
Guides
-
Professional and specialist guides
-
Law
-
Tourist guides and travel
-
Psychology
- Philosophy of life
- Interpersonal communication
- Mindfulness
- General
- Persuasion and NLP
- Academic psychology
- Psychology of soul and mind
- Work psychology
- Relacje i związki
- Parenting and children psychology
- Problem solving
- Intellectual growth
- Secret
- Sexapeal
- Seduction
- Appearance and image
- Philosophy of life
-
Religion
-
Sport, fitness, diets
-
Technology and mechanics
Videocourses
-
Data bases
-
Big Data
-
Biznes, ekonomia i marketing
-
Cybersecurity
-
Data Science
-
DevOps
-
For children
-
Electronics
-
Graphics/Video/CAX
-
Games
-
Microsoft Office
-
Development tools
-
Programming
-
Personal growth
-
Computer networks
-
Operational systems
-
Software testing
-
Mobile devices
-
UX/UI
-
Web development
-
Management
Podcasts
- Ebooks
- Programming
- C++
- C++. Struktury danych i algorytmy
E-book details
C++ to dojrzały język programowania o wielu różnych zastosowaniach. Inżynier oprogramowania, który chce w pełni skorzystać z jego zalet, powinien płynnie posługiwać się dostępnymi w tym języku strukturami danych i algorytmami. W ten sposób łatwiej można rozwiązywać konkretne problemy. Zastosowanie odpowiedniej struktury danych oraz algorytmu jest również ważne z punktu widzenia wydajności działania kodu, co bezpośrednio przekłada się na szybkość pracy aplikacji. Bez dogłębnego zrozumienia tych zagadnień bardzo trudno nauczyć się biegle programować w C++.
Dzięki tej książce dowiesz się, na czym polega implementacja klasycznych struktur danych i algorytmów w C++. Znajdziesz tu również przystępne wprowadzenie do podstawowych konstrukcji językowych oraz do korzystania z zintegrowanego środowiska programistycznego (IDE). Ponadto dowiesz się, w jaki sposób przechowywać dane za pomocą list wiązanych, tablic, stosów i kolejek, a także jak zaimplementować algorytmy sortowania, takie jak sortowanie szybkie i sortowanie przez kopcowanie, oraz algorytmy wyszukiwania, takie jak wyszukiwanie liniowe czy binarne. Kolejnym ważnym zagadnieniem ujętym w książce jest wysoka wydajność algorytmów operujących na ciągach znakowych i strukturach mieszających, jak również analiza algorytmów siłowych, zachłannych i wielu innych.
Najciekawsze zagadnienia ujęte w książce:
- podstawy C++, w tym kontrola przepływu kodu i abstrakcyjne typy danych
- listy, listy wiązane, stosy i kolejki
- algorytmy sortowania, w tym bąbelkowe, przez selekcję, wstawianie, scalanie
- tworzenie hierarchicznej struktury drzewa
- praktyczne aspekty implementacji algorytmów
C++. O jakości kodu decyduje algorytm i odpowiednia struktura danych!
- O autorze
- O recenzencie
- Wstęp
- Dla kogo jest ta książka?
- Zakres tematyczny książki
- Jak korzystać z tej książki?
- Przykłady kodu do pobrania
- Kolorowe wersje rysunków
- Konwencje
- 1. Struktury danych i algorytmy w C++
- Wymagania techniczne
- Podstawy C++
- Pierwszy kod w C++
- Usprawnianie pracy nad kodem przy użyciu IDE
- Definiowanie zmiennych przy użyciu podstawowych typów danych
- Sterowanie przepływem kodu
- Instrukcja warunkowa
- Pętle
- Wykorzystanie zmiennych za pośrednictwem zaawansowanych typów danych
- Tworzenie abstrakcyjnych typów danych
- Wykorzystanie klas C++ przy tworzeniu ADT zdefiniowanych przez użytkownika
- Posługiwanie się szablonami
- Szablony funkcji
- Szablony klas
- Biblioteka standardowych szablonów
- Analiza algorytmów
- Analiza asymptotyczna
- Najgorsze, średnie i najlepsze przypadki
- Notacja , O i
- Metoda rekurencyjna
- Analiza kosztu zamortyzowanego
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 2. Przechowywanie danych w listach i listach wiązanych
- Wymagania techniczne
- Tablice
- Tworzenie ADT listy
- Zwracanie elementu z listy
- Wstawianie elementu do listy
- Wyszukiwanie indeksu wybranego elementu w liście
- Usuwanie elementu z listy
- Implementacja listy
- Wprowadzenie do węzłów
- Tworzenie ADT listy jednokierunkowej
- Zwracanie elementu z listy wiązanej
- Wstawianie elementu do listy wiązanej
- Wyszukiwanie indeksu wybranego elementu w liście wiązanej
- Usuwanie elementu z listy wiązanej
- Implementacja listy wiązanej
- Tworzenie ADT listy dwukierunkowej
- Refaktoryzacja typu danych Node
- Refaktoryzacja kilku operacji LinkedList
- Usuwanie elementu
- Wstawianie elementu
- Implementacja ADT listy dwukierunkowej
- Refaktoryzacja typu danych Node
- Wykorzystanie typów List i LinkedList przy użyciu STL
- std::vector
- std::list
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 3. Tworzenie stosów i kolejek
- Wymagania techniczne
- Tworzenie ADT stosu
- Pobieranie wartości elementu z ADT stosu
- Umieszczanie elementów na ADT stosu
- Usuwanie elementów z ADT stosu
- Implementacja ADT stosu
- Inny przykład implementacji ADT stosu
- Tworzenie ADT kolejki jednokierunkowej
- Pobieranie wartości elementu z ADT kolejki
- Wstawianie elementu do ADT kolejki
- Usuwanie elementu z ADT kolejki
- Implementacja ADT kolejki
- Tworzenie ADT kolejki dwukierunkowej
- Pobieranie wartości elementu z ADT kolejki dwukierunkowej
- Dodawanie elementu do ADT kolejki dwukierunkowej
- Usuwanie elementu z ADT kolejki dwukierunkowej
- Implementacja ADT kolejki dwukierunkowej
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 4. Porządkowanie elementów przy użyciu algorytmów sortowania
- Wymagania techniczne
- Sortowanie bąbelkowe
- Sortowanie przez wybieranie
- Sortowanie przez wstawianie
- Sortowanie przez scalanie
- Sortowanie szybkie
- Sortowanie przez zliczanie
- Sortowanie pozycyjne
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 5. Wyszukiwanie elementów przy użyciu algorytmów wyszukiwania
- Wymagania techniczne
- Wyszukiwanie liniowe
- Opracowanie algorytmu wyszukiwania liniowego
- Implementacja algorytmu wyszukiwania liniowego
- Wyszukiwanie binarne
- Opracowanie algorytmu wyszukiwania binarnego
- Implementacja algorytmu wyszukiwania binarnego
- Wyszukiwanie ternarne
- Opracowanie algorytmu wyszukiwania ternarnego
- Zastosowanie algorytmu wyszukiwania ternarnego
- Wyszukiwanie interpolacyjne
- Opracowanie algorytmu wyszukiwania interpolacyjnego
- Zastosowanie algorytmu wyszukiwania interpolacyjnego
- Wyszukiwanie skokowe
- Opracowanie algorytmu wyszukiwania skokowego
- Zastosowanie algorytmu wyszukiwania skokowego
- Wyszukiwanie wykładnicze
- Opracowanie algorytmu wyszukiwania wykładniczego
- Wywołanie funkcji ExponentialSearch()
- Wyszukiwanie podlisty
- Opracowanie algorytmu wyszukiwania podlisty
- Wykorzystanie algorytmu wyszukiwania podlisty
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 6
- Używanie znakowego typu danych
- Wymagania techniczne
- Ciąg znakowy C++
- Tworzenie ciągu znaków przy użyciu tablicy znaków
- Dodatkowe funkcje std::string
- Zabawa słowami
- Tworzenie anagramów
- Wykrywanie palindromów
- Tworzenie ciągu z cyfr binarnych
- Konwertowanie liczb dziesiętnych na binarne
- Konwertowanie ciągu binarnego na dziesiętny
- Ciąg podsekwencji
- Generowanie podsekwencji z ciągu
- Sprawdzanie, czy ciąg jest podsekwencją innego ciągu
- Wyszukiwanie wzorca
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 7. Tworzenie hierarchicznej struktury drzewa
- Wymagania techniczne
- Tworzenie ADT drzewa binarnego
- Tworzenie ADT binarnego drzewa poszukiwań
- Wstawianie nowego klucza do BST
- Przechodzenie po BST po kolei
- Sprawdzanie obecności klucza w BST
- Zwracanie minimalnych i maksymalnych wartości kluczy
- Wyszukiwanie następnika klucza w BST
- Wyszukiwanie poprzednika klucza w BST
- Usuwanie węzła według podanego klucza
- Implementacja ADT BST
- Tworzenie ADT zrównoważonego BST (AVL)
- Rotacja węzłów
- Wstawianie nowego klucza
- Usuwanie wskazanego klucza
- Implementacja ADT AVL
- Tworzenie ADT kopca binarnego
- Sprawdzanie, czy kopiec jest pusty
- Wstawianie nowego elementu do kopca
- Pobieranie elementu o największej wartości
- Usuwanie elementu o największej wartości
- Implementacja stosu binarnego jako kolejki priorytetowej
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 8. Zestawianie wartości z kluczem w tablicy mieszającej
- Wymagania techniczne
- Wprowadzenie do tablic mieszających
- Dużo danych w małych komórkach
- Przechowywanie danych w tablicy mieszającej
- Obsługa kolizji
- Implementacja metody łańcuchowej
- Generowanie klucza mieszającego
- Opracowanie operacji Insert()
- Opracowanie operacji Search()
- Opracowanie operacji Remove()
- Opracowanie operacji IsEmpty()
- Zastosowanie ADT HashTable wykorzystującego metodę łańcuchową
- Implementacja techniki adresowania otwartego
- Opracowanie operacji Insert()
- Opracowanie operacji Search()
- Opracowanie operacji Remove()
- Opracowanie operacji IsEmpty()
- Opracowanie operacji PrintHashTable()
- Wdrożenie ADT HashTable wykorzystującego technikę szukania liniowego
- Podsumowanie
- Pytania
- Dodatkowe materiały
- 9. Implementacja algorytmów w praktyce
- Wymagania techniczne
- Algorytmy zachłanne
- Rozwiązanie problemu wydawania reszty
- Zastosowanie kodowania Huffmana
- Algorytmy dziel i zwyciężaj
- Rozwiązywanie problemów selekcyjnych
- Mnożenie macierzy
- Programowanie dynamiczne
- Ciąg Fibonacciego
- Programowanie dynamiczne i problem wydawania reszty
- Algorytmy siłowe
- Wyszukiwanie i sortowanie siłowe
- Wady i zalety algorytmów siłowych
- Algorytmy zrandomizowane
- Klasyfikacja algorytmów zrandomizowanych
- Generatory liczb losowych
- Zastosowania algorytmów zrandomizowanych
- Algorytmy z nawrotami
- Meblowanie nowego mieszkania
- Kółko i krzyżyk
- Podsumowanie
- Pytania
- Dodatkowe materiały
- Title: C++. Struktury danych i algorytmy
- Author: Wisnu Anggoro
- Original title: C++ Data Structures and Algorithms
- Translation: Maksymilian Gutowski
- ISBN: 978-83-283-5186-8, 9788328351868
- Date of issue: 2019-04-09
- Format: Ebook
- Item ID: cppstr
- Publisher: Helion