• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Stos - implementacja zrozumienie - wskaźniki wskaźników itd.

Object Storage Arubacloud
+1 głos
2,123 wizyt
pytanie zadane 18 stycznia 2016 w C i C++ przez Sinnley Stary wyjadacz (12,810 p.)

Witam, próbuję zrozumieć implementację stosu na język c++ ze strony algorytm.org.

Oprócz ogólnego zagmatwania nie rozumiem zapisu dwóch gwiazdek obok siebie. Udało mi się dowiedzieć, że ma to jakiś związek z tablicami kilkuwymarowymi, ale jaki jest ten związek i co tablice dwuwymiarowe robią w tym programie - tego już nie wiem. Byłbym bardzo wdzięczny za objaśnienie mi tej implementacji bo jest to dla mnie bardzo kłopotliwe a jednocześnie bardzo ważne. Kod z algorytmu wstawiam poniżej.

/stos
//www.algorytm.org
 
#include < iostream >
using namespace std;
 
struct liczba
{
int wartosc;
liczba *next;
 
};
 
//dodaj element do stosu (root)
void dodaj (liczba **root)
{  
liczba *nowa=new liczba;
cin>>nowa->wartosc;
nowa->next=*root;
*root=nowa;
}
 
//zdejmij element ze stosu (root)
void zdejmij (liczba **root)
{
if (*root) //sprawdz czy stos nie jest juz pusty
{
liczba *temp=*root;
*root=(*root)->next;
cout<<temp->wartosc<<endl;
delete temp;
}
}
 
int main()
{
char warunek;
liczba *root=NULL, *nowa = NULL;
while (cin>>warunek)
{
switch (warunek)
{
case 'd': //dodaj element do stosu
dodaj(&root);
break;
case 'z':
zdejmij(&root); //zdejmi element ze stosu
break;
case 'k': //zakoncz program
return 0;
}
}
 
return 0;
}

 

1 odpowiedź

0 głosów
odpowiedź 18 stycznia 2016 przez Patrycjerz Mędrzec (192,320 p.)

Podwójne gwiazdki to wskaźnik na wskaźnik i w tej sytuacji nie ma to żadnego związku z tablicą wielowymiarową. W tej implementacji został on wykorzystany po to, aby pracować na oryginalnym wskaźniku root.

Podobne pytania

0 głosów
3 odpowiedzi 722 wizyt
0 głosów
2 odpowiedzi 268 wizyt
pytanie zadane 11 stycznia 2021 w C i C++ przez Icar Nowicjusz (150 p.)
+1 głos
1 odpowiedź 1,671 wizyt
pytanie zadane 24 lutego 2018 w C i C++ przez Sic Dyskutant (8,510 p.)

92,576 zapytań

141,426 odpowiedzi

319,650 komentarzy

61,961 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...