Close Menu
    Ciekawe

    Jak zabezpieczyć pendrive hasłem bez dodatkowych programów?

    2025-11-13

    Ile kosztuje prowadzenie jednoosobowej działalności gospodarczej? Przegląd opłat

    2025-11-10

    Acer czy Asus – który laptop wybrać? Porównanie i porady

    2025-11-05
    Facebook X (Twitter) Instagram
    CPP Polska
    Facebook X (Twitter) Instagram
    • Biznes

      Ile kosztuje prowadzenie jednoosobowej działalności gospodarczej? Przegląd opłat

      2025-11-10

      Jak wziąć samochód w leasing bez firmy? Poradnik dla osób fizycznych

      2025-10-29

      Jak założyć firmę jednoosobową krok po kroku – koszty, formalności i czas trwania

      2025-10-23

      Ile kosztuje stworzenie strony internetowej dla firmy? Cennik i porady

      2025-10-07

      Jak usunąć profil firmy z Google i Facebooka? Instrukcja krok po kroku

      2025-10-07
    • Technologie

      Jak zabezpieczyć pendrive hasłem bez dodatkowych programów?

      2025-11-13

      Acer czy Asus – który laptop wybrać? Porównanie i porady

      2025-11-05

      Jak przenieść okno na drugi monitor? Skróty i metody dla Windows i macOS

      2025-11-01

      Jak sprawdzić specyfikację laptopa? Pełna konfiguracja sprzętowa

      2025-10-26

      Co to jest VR? Wirtualna rzeczywistość i jej zastosowania

      2025-10-20
    • Programowanie

      Maszyna stanów oparta o std::variant

      2025-10-07

      Tablice w C++ od podstaw – deklaracja, inicjalizacja, iteracja i typowe pułapki

      2025-10-07

      std::deque w C++ – kiedy wybrać dwukierunkową kolejkę zamiast vectora

      2025-10-07

      itoa i std::to_chars – konwersja liczb na tekst bez narzutu wydajności

      2025-10-07

      strcpy vs strncpy vs std::string – bezpieczne kopiowanie łańcuchów w C++

      2025-10-07
    • Inne

      Jak prowadzić blog programistyczny i dzielić się wiedzą?

      2025-06-28
    CPP Polska
    Home»C++»std::stack w C++ – adapter stosu, implementacja LIFO i przydatne metody
    C++

    std::stack w C++ – adapter stosu, implementacja LIFO i przydatne metody

    Oskar KlimkiewiczBy Oskar KlimkiewiczBrak komentarzy3 Mins Read
    Share Facebook Twitter LinkedIn Email Copy Link
    Follow Us
    RSS
    turned on computer monitor displaying coding application
    Share
    Facebook Twitter LinkedIn Email Copy Link

    Kompleksowy przegląd std::stack w C++ – implementacja LIFO, metody i zastosowania

    Stos (std::stack) to fundamentalna struktura danych w bibliotece standardowej C++, realizująca zasadę LIFO (Last-In, First-Out). Jako adapter kontenera, std::stack abstrahuje operacje na bazowym kontenerze (domyślnie std::deque), oferując minimalny interfejs do efektywnego zarządzania danymi w scenariuszach wymagających sekwencyjnego przetwarzania w odwróconej kolejności.

    Implementacja LIFO

    Mechanizm LIFO w std::stack polega na ograniczeniu operacji do jednego końca struktury danych:

    • Wstawianie (push) – nowe elementy dodawane są wyłącznie na wierzchołek stosu;
    • Usuwanie (pop) – elementy usuwane są wyłącznie z wierzchołka stosu;
    • Dostęp (top) – jedynym elementem dostępnym bez modyfikacji struktury jest element wierzchołkowy.
      Ta semantyka odwzorowuje zachowanie stosu fizycznego (np. stosu talerzy), gdzie ostatnio dodany element jest pierwszym do usunięcia.

    Metody i ich zastosowania

    Interfejs std::stack składa się z sześciu kluczowych metod:

    1. push(const Type& val) – dodaje element na wierzchołek stosu poprzez kopię lub przeniesienie;
      std::stack<int> s;
      s.push(42); // Wstawia 42 na wierzchołek
    2. emplace(Args&&... args) – konstruuje element w miejscu na wierzchołku stosu, unikając kopiowania;
      s.emplace(100); // Efektywniejsze niż push dla obiektów złożonych
    3. pop() – usuwa element z wierzchołka bez zwracania wartości. Wymaga wcześniejszego odczytu top();
      s.pop(); // Usuwa wierzchołek
    4. top() – zwraca referencję do elementu na wierzchołku, pozwala na modyfikację wartości;
      s.top() = 99; // Modyfikuje wierzchołek
    5. size() – zwraca liczbę elementów przechowywanych na stosie;
      cout << s.size(); // Np. 3 elementy
    6. empty() – sprawdza obecność elementów na stosie. Zwraca true dla stosu pustego;
      if (s.empty()) { /* ... */ } // Logika dla pustego stosu

    Zaawansowane techniki

    • Wybór kontenera bazowego – domyślnie std::stack wykorzystuje std::deque, lecz możliwe jest zastosowanie alternatywnych kontenerów spełniających wymagania SequenceContainer (np. std::list, std::vector);
      std::stack<int, std::list<int>> customStack; // Stos z listą jako kontenerem
    • Optymalizacje – emplace vs push: emplace unika tworzenia tymczasowych obiektów, redukując narzuty pamięciowe, swap(): zamienia zawartości dwóch stosów w czasie stałym O(1) poprzez wymianę wskaźników kontenerów bazowych.

    Przykład praktyczny: odwracanie sekwencji

    using namespace std;
    
    vector<int> reverseVector(const vector<int>& input) {
        stack<int> s;
        for (int elem : input) s.push(elem); // Wstawianie elementów
    
        vector<int> reversed;
        while (!s.empty()) {
            reversed.push_back(s.top()); // Pierwszy element: ostatni dodany
            s.pop();
        }
        return reversed; // Zwraca odwrócony wektor
    }
    

    Ograniczenia i ostrzeżenia

    1. Brak iteratorów – std::stack nie udostępnia iteratorów, uniemożliwiając przeglądanie elementów bez modyfikacji struktury;
    2. Bezpieczeństwo wyjątków – metoda pop() nie zwraca wartości, by zagwarantować silną gwarancję wyjątków. Odczyt wymaga oddzielnego wywołania top().

    Zastosowania w algorytmach

    • Przeszukiwanie w głąb (DFS) – stos przechowuje wierzchołki do odwiedzenia;
    • Ewaluacja wyrażeń – przetwarzanie notacji odwrotnej polskiej;
    • Cofanie operacji – historia działania programu (np. mechanizm undo).

    Podsumowanie

    std::stack oferuje minimalistyczny, lecz potężny interfejs dla struktur LIFO, będąc niezastąpionym narzędziem w scenariuszach wymagających sekwencyjnego przetwarzania danych w odwróconej kolejności. Elastyczność w doborze kontenera bazowego oraz wydajność operacji emplace i swap czynią ją kluczowym komponentem biblioteki standardowej C++.

    Polecane:

    • std::priority_queue – implementacja kopca, własne komparatory i zastosowania algorytmiczne
    • STL w C++ – szybki przegląd kontenerów, adapterów i algorytmów dla początkujących
    • Erase–remove idiom w C++
    • Flagi -Wall i -Wextra to nie wszystko – przydatne opcje GCC
    • Praktyczne użycie std::optional w nowoczesnym C++
    Share. Facebook Twitter LinkedIn Email Copy Link
    Oskar Klimkiewicz
    • Website

    Inżynier oprogramowania specjalizujący się w C++, absolwent Wydziału Elektroniki i Technik Informacyjnych Politechniki Warszawskiej. Od ponad 8 lat projektuje i rozwija systemy o wysokiej dostępności, głównie dla branży fintech i IoT. PS. Zdjęcie wyretuszowane przez AI :)

    Podobne artykuły

    Maszyna stanów oparta o std::variant

    8 Mins Read

    Tablice w C++ od podstaw – deklaracja, inicjalizacja, iteracja i typowe pułapki

    4 Mins Read

    std::deque w C++ – kiedy wybrać dwukierunkową kolejkę zamiast vectora

    4 Mins Read
    Leave A Reply Cancel Reply

    Oglądaj, słuchaj, ćwicz - zdobywaj nowe umiejętności online
    Nie przegap

    Jak zabezpieczyć pendrive hasłem bez dodatkowych programów?

    Oskar Klimkiewicz5 Mins Read

    Zabezpieczenie danych na przenośnych nośnikach USB jest kluczowe we współczesnym środowisku cyfrowym, gdzie zagrożenia cybernetyczne…

    Ile kosztuje prowadzenie jednoosobowej działalności gospodarczej? Przegląd opłat

    2025-11-10

    Acer czy Asus – który laptop wybrać? Porównanie i porady

    2025-11-05

    Jak przenieść okno na drugi monitor? Skróty i metody dla Windows i macOS

    2025-11-01
    Social media
    • Facebook
    • Twitter
    • LinkedIn
    O nas
    O nas

    CPP Polska to serwis internetowy poświęcony technologii, programowaniu, IT, biznesowi i finansom. Znajdziesz tu porady, wskazówki i instrukcje dla wszystkich czytelników IT & Tech & Biz.

    Facebook X (Twitter) LinkedIn RSS
    Najnowsze

    Jak zabezpieczyć pendrive hasłem bez dodatkowych programów?

    2025-11-13

    Ile kosztuje prowadzenie jednoosobowej działalności gospodarczej? Przegląd opłat

    2025-11-10

    Acer czy Asus – który laptop wybrać? Porównanie i porady

    2025-11-05
    Popularne

    Skrajnie niepotrzebne, skrajne przypadki w C++

    2025-06-28

    Wyszukiwanie testów w Google Test – metody i narzędzia

    2025-06-28

    Czy C jest wolniejszy od C++? Zero-cost abstraction w praktyce

    2025-06-28
    © 2025 CPP Polska. Wszelkie prawa zastrzeżone.
    • Lista publikacji
    • Współpraca
    • Kontakt

    Type above and press Enter to search. Press Esc to cancel.