Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

Kaburagi

[PASCAL] Stos

Rekomendowane odpowiedzi

Witam!

Zrobiłem stos ze zmiennymi dynamicznymi, niemniej nie jestem pewien czy wszystko jest tak jak należy.

Niby wszystko śmiga i żądane czynności się wykonują, ale preferuję by ktoś swoim doświadczonym okiem na to spojrzał i mnie upewnił. :)

 

Oto kod:

uses
   crt;
type
   wskaznik_stosu=^skladnik_stosu;
   skladnik_stosu=record
                        dane:string;
                        wskaznik:wskaznik_stosu;
   end;
var
  wierzcholek,punkt:wskaznik_stosu;
  i:integer;

function menu:char;
begin
clrscr;
writeln('[D] Dodawanie na stos');
writeln('[W] Wyswietlanie stosu');
writeln('[Z] Zdejmowanie ze stosu');
writeln('[X] Kasowanie stosu');
writeln('[K] Koniec programu');
menu:=upcase(readkey);
end;

procedure dodawanie;
var
  znak:char;
begin
repeat
if i=0 then
begin
    clrscr;
    i:=1;
    new(wierzcholek);
    write('Dane: ');
    readln(wierzcholek^.dane);
    wierzcholek^.wskaznik:=nil;
    punkt:=wierzcholek;
    writeln('N - konczy, inny kontynuuje');
    znak:=upcase(readkey);
end
else
if i<>0 then
begin
    clrscr;
    new(wierzcholek);
    write('Dane: ');
    readln(wierzcholek^.dane);
    wierzcholek^.wskaznik:=punkt;
    punkt:=wierzcholek;
    writeln('N - konczy, inny kontynuuje');
    znak:=upcase(readkey);
end;
until znak='N';
end;

procedure wyswietlanie;
begin
clrscr;
while punkt<>nil do
     begin
          writeln(punkt^.dane);
          punkt:=punkt^.wskaznik;
     end;
if punkt=nil then i:=0;
readln;
end;

procedure kasowanie;
var
  temp:wskaznik_stosu;
begin
    clrscr;
    while punkt <> nil do
          begin
               dispose(wierzcholek);
               wierzcholek:=punkt;
          end;
     writeln('Stos skasowany');
     i:=0;
     readln;
end;

procedure zdejmowanie;
begin
clrscr;
dispose(wierzcholek);
punkt:=wierzcholek^.wskaznik;
wierzcholek:=punkt;
writeln('Wierzcholek zdjety');
readln;
end;

begin
i:=0;
repeat
clrscr;
case menu of
    'D':dodawanie;
    'Z':zdejmowanie;
    'X':kasowanie;
    'W':wyswietlanie;
    'K':halt;
end;
until false;
end.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Oj chyba źle masz wyświetlanie i dodawanie wyświetlić można tylko raz jak chcę dopisać coś do stosu stos się kasuje i robi się nowy.

może będzie działać nie obiecuję.

procedure wyswietlanie;
begin
clrscr;
     punkt:=wierzcholek;
while punkt<>nil do
     begin
          writeln(punkt^.dane);
          punkt:=punkt^.wskaznik;
     end;
if punkt=nil then i:=0;{<=== to jest raczej niepotrzebne}
readln;
end;

 

 

Pozdro Paciorrro.

 

PS. Kasowanie też nie działa ;)

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Fakt, nie zwróciłem na to uwagi :P

Co do dopisywanie do stosu - to wszystko jest dobrze (tzn. tak ma być)...

Wyświetlanie już też chodzi w pętli...

Kasowanie stosu też już śmiga :)

 

 

 

Poprawiony kod:

uses
   crt;
type
   wskaznik_stosu=^skladnik_stosu;
   skladnik_stosu=record
                        dane:string;
                        wskaznik:wskaznik_stosu;
   end;
var
  wierzcholek,punkt:wskaznik_stosu;
  i:integer;

function menu:char;
begin
clrscr;
writeln('[D] Dodawanie na stos');
writeln('[W] Wyswietlanie stosu');
writeln('[Z] Zdejmowanie ze stosu');
writeln('[X] Kasowanie stosu');
writeln('[K] Koniec programu');
menu:=upcase(readkey);
end;

procedure dodawanie;
var
  znak:char;
begin
repeat
if i=0 then
begin
    clrscr;
    i:=1;
    new(wierzcholek);
    write('Dane: ');
    readln(wierzcholek^.dane);
    wierzcholek^.wskaznik:=nil;
    punkt:=wierzcholek;
    writeln('N - konczy, inny kontynuuje');
    znak:=upcase(readkey);
end
else
if i<>0 then
begin
    clrscr;
    new(wierzcholek);
    write('Dane: ');
    readln(wierzcholek^.dane);
    wierzcholek^.wskaznik:=punkt;
    punkt:=wierzcholek;
    writeln('N - konczy, inny kontynuuje');
    znak:=upcase(readkey);
end;
until znak='N';
end;

procedure wyswietlanie;
begin
clrscr;
      punkt:=wierzcholek;
while punkt<>nil do
     begin
          writeln(punkt^.dane);
          punkt:=punkt^.wskaznik;
     end;
readln;
end;

procedure kasowanie;
var
  temp:wskaznik_stosu;
begin
    clrscr;
    punkt:=wierzcholek;
    while punkt <> nil do
          begin
               dispose(wierzcholek);
               punkt:=wierzcholek^.wskaznik;
               wierzcholek:=punkt;
          end;
     writeln('Stos skasowany');
     i:=0;
     readln;
end;

procedure zdejmowanie;
begin
clrscr;
dispose(wierzcholek);
punkt:=wierzcholek^.wskaznik;
wierzcholek:=punkt;
writeln('Wierzcholek zdjety');
readln;
end;

begin
i:=0;
repeat
clrscr;
case menu of
    'D':dodawanie;
    'Z':zdejmowanie;
    'X':kasowanie;
    'W':wyswietlanie;
    'K':halt;
end;
until false;
end.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Łap dobry stos :D

uses crt;
type wskaznik_stosu=^skladnik_stosu;
skladnik_stosu=record
	dane:String;
	wskaznik:wskaznik_stosu;
end;
var
wierzcholek,punkt:wskaznik_stosu;

function menu:char;
begin
clrscr;
writeln('[1] - Dodawanie');
writeln('[2] - Wyswietlanie');
writeln('[3] - Zdejmowanie');
writeln('[4] - Kasowanie');
writeln('[Esc] - Wyjscie z programu');
menu:=readkey;
end;
procedure dodaj;
var
znak:char;
begin
repeat
clrscr;
punkt:=wierzcholek;
new(wierzcholek);
	write('Dane: ');
	readln(wierzcholek^.dane);
wierzcholek^.wskaznik:=punkt;
writeln('N - konczy, inny kontynuuje');
	znak:=upcase(readkey);
until znak='N';
end;
procedure wyswietl;
begin
clrscr;
punkt:=wierzcholek;
   Repeat
         writeln(punkt^.dane);
         punkt:=punkt^.wskaznik;
   until punkt=nil;
end;
procedure zdejmij;
begin
clrscr;;
    punkt:=wierzcholek;
    dispose(wierzcholek);
    punkt:=wierzcholek^.wskaznik;
    wierzcholek:=punkt;
writeln('Wierzcholek zdjety');
end;
procedure usun;
begin
clrscr;
  repeat
        punkt:=wierzcholek;
        dispose(wierzcholek);
        punkt:=wierzcholek^.wskaznik;
        wierzcholek:=punkt;
  until punkt=nil;
	writeln('Stos usuniety');
end;

begin
repeat
clrscr;

case menu of
'1':dodaj;
'2':wyswietl;
'3':zdejmij;
'4':usun;
#27:halt;
end;
	writeln;
	writeln('Aby wrocic do menu nacisnij [ENTER]');
readln;
until false;
end.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...