Detalii evaluare #36980763

Rezumat problemă

#2173 iepuri1

Un gospodar are N iepuri (pe care i-a numerotat de la 1 la N) și foarte mulți morcovi. Ce e mai deosebit în această gospodărie este că iepurii sunt organizați ierarhic, în funcție de vârstă, autoritate și nevoile nutriționale. Astfel, fiecare iepure are exact un șef direct (exceptându-l pe Rilă Iepurilă, care este șeful cel mare, șeful tuturor iepurilor). Orice iepure poate avea 0, 1 sau mai mulți subordonați direcți. Orice iepure-șef va mânca cel puțin un morcov mai puțin decât fiecare dintre subordonații săi direcți. Gospodarul nu se poate hotărî câți morcovi să dea fiecărui iepure și ar vrea să știe în câte moduri poate împărți morcovi la iepuri știind că fiecare iepure poate să mănânce minim un morcov și maxim K morcovi. Scrieți un program care calculează numărul de posibilități modulo 30011 de a împărți morcovi la cei N iepuri știind că orice iepure poate mânca între 1 și K morcovi și trebuie să mănânce cu cel puțin un morcov mai puțin decât fiecare dintre iepurii care îi sunt subordonați direcți.

Detalii

Problema iepuri1 Operații I/O iepuri1.in/iepuri1.out
Limita timp 0.1 secunde Limita memorie Total: 16 MB / Stivă 8 MB
Id soluție #36980763 Utilizator Ivan Dragos (cyg_dragos10)
Fișier iepuri1.cpp Dimensiune 1.09 KB
Data încărcării 06 Iunie 2022, 14:39 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

iepuri1.cpp: In function 'void readinput()':
iepuri1.cpp:17:26: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for( int i = 0; i < N - 1; i++ )

                          ^
iepuri1.cpp:23:7: error: 'i' was not declared in this scope
  for( i = 1; i <= N; i++ )

       ^
iepuri1.cpp: In function 'void go(unsigned int)':
iepuri1.cpp:31:33: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for( int i = 1; i <= arb[rad][0]; i++ )

                                 ^
iepuri1.cpp:37:34: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for( int i = 1; i <= arb[rad][0]; i++ )

                                  ^
iepuri1.cpp: In function 'void writeoutput()':
iepuri1.cpp:53:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for( int i = 1; i <= K; i++ )

                       ^
iepuri1.cpp: In function 'void readinput()':
iepuri1.cpp:14:37: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
  freopen( "iepuri.in", "rt", stdin );

                                     ^
iepuri1.cpp:15:25: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf( "%u%u", &N, &K );

                         ^
iepuri1.cpp:19:26: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf( "%u%u", &a, &b );

                          ^
iepuri1.cpp: In function 'void writeoutput()':
iepuri1.cpp:59:39: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
  freopen( "iepuri.out", "wt", stdout );

                                       ^

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 iepuri1 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ă.