Kaj je std :: stack?
Sklop je podatkovna struktura, ki deluje na podlagi tehnike LIFO (Last In First Out). Stog std :: omogoča dodajanje in odstranjevanje elementov samo z enega konca.
Razred std :: stack je vmesnik vsebnika. Predmeti vsebnika vsebujejo podatke podobnega podatkovnega tipa. Sklop lahko ustvarite iz različnih vsebnikov zaporedja. Če posoda ni na voljo, bo privzeto uporabljena deka kontaina. Vmesniki vsebnikov ne podpirajo iteratorjev, zato jih ni mogoče uporabljati za obdelavo podatkov.
V tej vadnici C ++ se boste naučili
- Kaj je std :: stack?
- Skladnja sklada
- Vrste članov
- Operacije v skladišču
- Izvajanje sklada
- push () in pop ()
- prazno (), velikost (), zgoraj ()
- emplace () in swap ()
- Zložite v STL
Skladnja sklada
Če želite ustvariti sklad, moramo v kodo vključiti datoteko glave
template> class stack;
- Type - je vrsta elementa v std :: stack. Lahko je kateri koli veljaven tip C ++ ali celo uporabniško določen tip.
- Vsebnik - je vrsta osnovnega predmeta vsebnika.
Vrste članov
Tu so vrste članov skladov:
- value_type - prvi parameter predloge, T. Označuje vrste elementov.
- container_type - drugi parameter predloge, Container. Označuje osnovni tip vsebnika.
- size_type - Nepodpisani integralni tip.
Operacije v skladišču
Sklop C ++ podpira naslednje osnovne operacije:
- push - doda / potisne element v sklad.
- pop - Odstrani / odpre element iz sklada.
- peek - vrne zgornji element sklada, ne da bi ga odstranil.
- isFull - Preveri, ali je sklad poln.
- isEmpty - Preveri, ali je sklad prazen.
Izvajanje sklada
1. korak) Na začetku imamo prazen kup. Vrh praznega sklada je nastavljen na -1.
Korak 2) Nato smo element 5 potisnili v sklad. Zgornji del sklada bo usmerjen na element 5.
Korak 3) Nato smo potisnili element 50 v sklad. Vrh sklada se premakne in kaže na element 50.
4. korak) Nato smo izvedli pojavno operacijo in odstranili zgornji element iz sklada. Element 50 je izpuščen iz sklada. Zgornji del sklada zdaj kaže na element 5.
push () in pop ()
Funkcije stack :: push () dodajo nov element na vrh sklada. Velikost sklada se po vstavitvi poveča za 1. Funkcija ima to sintakso:
stack.push(value)
Vrednost je element, ki ga želite vstaviti v sklad.
Funkcija stack :: pop () odstrani zgornji element sklada. To je najnovejši element sklada. Velikost sklada se po odstranitvi zmanjša za 1. Tu je sintaksa funkcije:
stack.pop()
Funkcija ne zajema nobenih parametrov.
Primer 1:
#include#include using namespace std;int main() {stack st;st.push(10);st.push(20);st.push(30);st.push(40);st.pop();st.pop();while (!st.empty()) {cout << ' ' << st.top();st.pop();}}
Izhod:
Tu je posnetek zaslona kode:
Razlaga kode:
- V našo kodo vključite datoteko glave iostream, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite datoteko glave sklada, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite imenski prostor std, da lahko uporabljate njegove razrede, ne da bi ga poklicali.
- Pokličite glavno funkcijo. V to funkcijo je treba dodati programsko logiko.
- Ustvari niz skladov za shranjevanje celoštevilnih vrednosti.
- S funkcijo push () vstavite vrednost 10 v sklad.
- S funkcijo push () vstavite vrednost 20 v sklad.
- S pomočjo funkcije push () vstavite vrednost 30 v sklad.
- S funkcijo push () vstavite vrednost 40 v sklad.
- S funkcijo pop () odstranite zgornji element iz sklada, to je 40. Zgornji element zdaj postane 30.
- S funkcijo pop () odstranite zgornji element iz sklada, to je 30. Zgornji element zdaj postane 20.
- Uporabite funkcijo while loop in empty (), da preverite, ali sklad ni prazen. The! je operater NOT.
- Tiskanje trenutne vsebine sklada na konzoli.
- Pokličite funkcijo pop () na kupu.
- Konec telesa zanke while.
- Konec telesa glavne () funkcije.
prazno (), velikost (), zgoraj ()
Skladi imajo vgrajene funkcije, s katerimi se lahko poigrate s skladom in njegovimi vrednostmi. Tej vključujejo:
- empty () - preveri, ali je sklad prazen ali ne.
- size () - vrne velikost sklada, to je število elementov v kupčku.
- top () - dostopa do elementa sklada na vrhu.
2. primer:
#include#include using namespace std;void createStack(stack mystack){stack ms = mystack;while (!ms.empty()){cout << '\t' << ms.top();ms.pop();}cout << '\n';}int main(){stack st;st.push(32);st.push(21);st.push(39);st.push(89);st.push(25);cout << "The stack st is: ";createStack(st);cout << "\n st.size() : " << st.size();cout << "\n st.top() : " << st.top();cout << "\n st.pop() : ";st.pop();createStack(st);return 0;}
Izhod:
Tu je posnetek zaslona kode:
Razlaga kode:
- V našo kodo vključite glavo glave iostream, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite datoteko glave sklada, da boste lahko uporabljali njene funkcije.
- V naš program vključite imenski prostor std, da lahko uporabljate njegove razrede, ne da bi ga poklicali.
- Ustvari funkcijo createStack, ki jo lahko uporabimo za ustvarjanje sklada mystack. Sklad vsebuje nabor celih števil.
- Začetek telesa funkcije createStack.
- Ustvarite primerek podatkovnega tipa mystack in mu dajte ime ms.
- Z zanko while in funkcijo empty () preverite, ali je sklad prazen.
- Začetek telesa zanke while.
- Uporabite funkcijo top (), shranjeno na vrhu sklada. Znak \ t bo ustvaril nov zavihek.
- S funkcijo pop () izbrišite element na vrhu sklada.
- Konec telesa zanke while.
- Na konzolo natisnite prazno vrstico.
- Konec telesa funkcije createStack.
- Pokličite glavno funkcijo. Logiko programa je treba dodati v telo funkcije main ().
- Začetek telesa funkcije main ().
- Ustvari objekt sklada st.
- S funkcijo push () vstavite element 32 v sklad.
- S pomočjo funkcije push () vstavite element 21 v sklad.
- S funkcijo push () vstavite element 39 v sklad.
- S pomočjo funkcije push () vstavite element 89 v sklad.
- S pomočjo funkcije push () vstavite element 25 v sklad.
- Na konzolo natisnite nekaj besedila.
- Za izvedbo zgornjih operacij vstavljanja v sklad pokličite funkcijo createStack.
- Na konzolo natisnite velikost sklada skupaj z drugim besedilom.
- Natisnite element na vrh sklada na konzoli.
- Na konzolo natisnite nekaj besedila.
- Izbrišite element na vrhu sklada. Nato bo vrnil preostale elemente v skladišču.
- Za izvedbo zgornjih operacij pokličite funkcijo createStack.
- Program mora po uspešnem zaključku vrniti vrednost.
- Konec telesa funkcije main ().
emplace () in swap ()
To so druge vgrajene funkcije sklada:
- emplace () - konstruira nato vstavi nov element na vrh sklada.
- swap () - izmenjuje vsebino skladov z vsebino drugega sklada.
3. primer:
#include#include #include using namespace std;int main() {stack st1;stack st2;st1.emplace(12);st1.emplace(19);st2.emplace(20);st2.emplace(23);st1.swap(st2);cout << "st1 = ";while (!st1.empty()) {cout << st1.top() << " ";st1.pop();}cout << endl << "st2 = ";while (!st2.empty()) {cout << st2.top() << " ";st2.pop();}}
Izhod:
Tu je posnetek zaslona kode:
Razlaga kode:
- V našo kodo vključite datoteko glave iostream, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite datoteko glave sklada, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite glavo cstdlib, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite imenski prostor std, da lahko uporabljate njegove razrede, ne da bi ga poklicali.
- Pokličite glavno funkcijo. V telesu te funkcije bo dodana programska logika.
- Deklarirajte sklad z imenom st1 za shranjevanje celoštevilnih vrednosti.
- Deklarirajte sklad z imenom st2 za shranjevanje celoštevilnih vrednosti.
- S funkcijo emplace () vstavite celo število 12 v sklad z imenom st1.
- S funkcijo emplace () vstavite celo število 19 v sklad z imenom st1.
- S funkcijo emplace () vstavite celo število 20 v sklad z imenom st2.
- S funkcijo emplace () vstavite celo število 23 v sklad z imenom st2.
- S funkcijo swap () zamenjajte vsebino obeh skladov, st1 in st2. Vsebino sklada st1 je treba premakniti v sklad st2. Vsebino sklada st2 je treba premakniti v sklad st1.
- Na konzolo natisnite nekaj besedila.
- Uporabite stavek while in funkcijo empty (), da preverite, ali sklad st1 ni prazen.
- Na konzolo natisnite vsebino sklada st1. "Med dodajanjem prostora na elemente sklada doda prostor med tiskanjem na konzolo.
- Izvedite funkcijo pop () na kupu st1, da odstranite zgornji element.
- Konec telesa stavka while.
- Na konzolo natisnite nekaj besedila. Endl je ključna beseda C ++ za končno vrstico. Kazalec miške premakne v naslednjo vrstico, da začne tiskati od tam.
- Uporabite stavek while in funkcijo empty (), da preverite, ali sklad st2 ni prazen.
- Natisnite vsebino sklada st2 na konzolo. "Med dodajanjem prostora na elemente sklada doda prostor med tiskanjem na konzolo.
- Izvedite funkcijo pop () na skladu st2, da odstranite zgornji element.
- Konec telesa stavka while.
- Konec telesa glavne () funkcije.
Zložite v STL
STL (Standard Template Library) ima razrede predlog, ki zagotavljajo skupne podatkovne strukture C ++. Zato je sklad mogoče uporabiti tudi v STL. To knjižnico preprosto vključimo v našo kodo in z njo določimo sklad.
stackst;
Zgornja sintaksa razglaša sklad st za elemente podatkovnega tipa T.
3. primer:
#include#include #include using namespace std;int main() {stack st;st.push(12);st.push(19);st.push(20);cout << st.top();cout << st.size();}
Izhod:
Tu je posnetek zaslona kode:
Razlaga kode:
- V našo kodo vključite datoteko glave iostream, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite datoteko glave sklada, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite glavo cstdlib, da boste lahko uporabljali njene funkcije.
- V našo kodo vključite imenski prostor std, da lahko uporabljate njegove razrede, ne da bi ga poklicali.
- Pokličite glavno funkcijo. V telo te funkcije je treba dodati programsko logiko.
- Za shranjevanje celoštevilčnih podatkov razglasite st. St.
- Dodajte element 12 v sklad.
- V sklad dodajte element 19.
- Dodajte element 20 v sklad.
- Natisnite element na vrh sklada na konzoli.
- Na konzolo natisnite velikost sklada.
- Konec telesa funkcije main ().
Povzetek:
- Sklop je podatkovna struktura, ki deluje na podlagi tehnike LIFO (Last In First Out).
- Stog std :: omogoča samo dodajanje in odstranjevanje elementov z enega konca.
- Razred std :: stack je vmesnik vsebnika, ki vsebuje elemente podobnega podatkovnega tipa.
- Sklad je mogoče ustvariti iz različnih zabojnikov za zaporedje.
- Če ne navedete vsebnika, bo privzeto uporabljen deque vsebnik.
- Funkcija push () je namenjena vstavljanju predmetov v sklad.
- Funkcija pop () je namenjena odstranjevanju zgornjega elementa iz koraka.
- Funkcija empty () je namenjena preverjanju, ali je sklad prazen ali ne.