Detalii evaluare #57442731

Rezumat problemă

books

#2650

Eroul nostru, Căldărușe, are un număr n de cărți pe care le are aranjate una peste cealaltă (sub forma unui stack). Cartea din vârf are valoarea \( {a}_{1} \), următoarea \( {a}_{2} \) și așa mai departe. Cartea de la bază are indicele n (\( {a}_{n} \)). Toate numerele sunt distincte. Căldărușe vrea să mute toate cărțile în ghiozdanul lui în exact n pași. În timpul pasului de ordin i, el vrea să mute cartea cu numărul \( {b}_{i} \) în ghiozdan. Dacă această carte se află în stack, el o ia atât pe ea, cât și toate cărțile situate deasupra acesteia și le pune în ghiozdan; în caz contrar, el nu va face nimic și va trece la următorul pas. Ajutați-l pe Căldărușe! Spuneți-i voi numărul de cărți pe care le va pune în ghiozdan în timpul fiecărui pas.

Detalii

Problema books Operații I/O tastatură/ecran
Limita timp 0.7 secunde Limita memorie Total: 64 MB / Stivă 8 MB
Id soluție #57442731 Utilizator Goga Octavian (SILVO)
Fișier books.c Dimensiune 1.06 KB
Data încărcării 31 Martie 2025, 17:03 Scor / rezultat Eroare de compilare

Evaluare

Mesaj compilare

books.c:4:1: error: unknown type name 'STACK'
 STACK *new_stack(int n){

 ^
books.c: In function 'new_stack':
books.c:5:5: error: unknown type name 'STACK'
     STACK *s = (STACK *)malloc(sizeof(STACK));

     ^
books.c:5:17: error: 'STACK' undeclared (first use in this function)
     STACK *s = (STACK *)malloc(sizeof(STACK));

                 ^
books.c:5:17: note: each undeclared identifier is reported only once for each function it appears in
books.c:5:24: error: expected expression before ')' token
     STACK *s = (STACK *)malloc(sizeof(STACK));

                        ^
books.c:6:6: error: request for member 'v' in something not a structure or union
     s->v = (int *)malloc(sizeof(int) * n);

      ^
books.c:7:6: error: request for member 'len' in something not a structure or union
     s->len = 0;

      ^
books.c:8:6: error: request for member 'top' in something not a structure or union
     s->top = 0;

      ^
books.c: In function 'citire':
books.c:33:9: warning: format '%d' expects argument of type 'int *', but argument 2 has type 'int' [-Wformat=]
         scanf("%d", v[i]);

         ^
books.c: In function 'main':
books.c:41:16: warning: initialization from incompatible pointer type [enabled by default]
     STACK *s = new_stack(n);

                ^
books.c:42:16: warning: initialization from incompatible pointer type [enabled by default]
     STACK *t = new_stack(n);

                ^
books.c: In function 'citire':
books.c:33:14: warning: ignoring return value of 'scanf', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d", v[i]);

              ^
books.c: In function 'main':
books.c:39:10: warning: ignoring return value of 'scanf', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d", &n);

          ^
books.c:47:14: warning: ignoring return value of 'scanf', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d", &x);

              ^
books.c:53:14: warning: ignoring return value of 'scanf', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d",  &w[i]);

              ^

Cum funcționează evaluarea?

www.pbinfo.ro permite evaluarea a două tipuri de probleme:

  • probleme la care rezolvarea presupune scrierea unui program complet
  • probleme la care rezolvarea presupune scrierea unei secvențe de program - câteva instrucțiuni, o listă de declarații, una sau mai multe funcții, etc.

Problema books face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:

  • Programul sursă este compilat folosind compilatorul corespunzător. Dacă în urma compilării se obțin erori sau avertismente, acestea sunt afișate în această pagină.
  • Dacă programul a fost compilat, executabilul obținut va fi rulat, furnizându-i-se unul sau mai multe seturi de date de intrare, în concordanță cu restricțiile specifice problemei. Pentru fiecare set de date se obține un anumit punctaj, în raport cu corectitudinea soluției tale.

Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.

Du-te sus!