Detalii evaluare #43577363

Rezumat problemă

#692 robot

Studenţii Facultăţii de Informatică din cadrul Universităţii din Cluj, au conceput roboţi care şterg praful, plantează copaci, pun gresie, servesc masa, etc.

Botezat „Rosie“, robotul care şterge praful are două braţe ( S – stâng şi D – drept) pe care sunt montate nişte perii ce sunt învârtite cu ajutorul unui motoraş. Braţul robotului este programat să se poziţioneze în dreptul unei suprafeţe, periile învârtite de motoraş parcurg suprafaţa ştergând în acest fel praful de pe ea.

Pentru o demonstraţie, robotul este aşezat în faţa unei etajere cu N rafturi numerotate în ordine, de jos în sus, cu numere de la 1 la N. Braţul stâng ( S ) al robotului este poziţionat în dreptul primului raft iar celălat braţ ( D ) în dreptul celui de-al K-lea raft.

Pentru ştergerea prafului, deplasarea braţelor robotului este programată astfel:

  • fiecare braţ se deplasează doar de jos în sus, de la raftul în dreptul căruia este poziţionat la un moment dat, la raftul situat imediat deasupra acestuia;
  • din minut în minut, se deplasează doar unul din braţe, se poziţionează în dreptul raftului corespunzător şi şterge praful de pe acesta;
  • dacă ambele braţe ajung în dreptul aceluiaşi raft, atunci robotul se blochează şi demonstraţia se încheie fără succes.

Ştiind că demonstraţia se termină în momentul în care braţul drept ( D ) al robotului a ajuns pe ultimul raft al etajerei, scrieţi un program care calculează numărul M de modalităţi diferite în care poate fi programat robotul pentru a asigura succesul demonstraţiei.

Programul va afişa restul împărţirii numărului M la 64997.

Detalii

Problema robot Operații I/O robot.in/robot.out
Limita timp 0.1 secunde Limita memorie Total: 16 MB / Stivă 16 MB
Id soluție #43577363 Utilizator Haivas Horia (HoriaHaivas)
Fișier robot.cpp Dimensiune 1.85 KB
Data încărcării 04 Mai 2023, 10:49 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

robot.cpp: In function 'int main()':
robot.cpp:30:9: error: #pragma GCC optimize is not allowed inside functions
 #pragma GCC optimize("Ofast")

         ^
robot.cpp:39:1: error: a function-definition is not allowed here before '{' token
 {

 ^
robot.cpp:23:9: warning: unused variable 'n' [-Wunused-variable]
     int n,k,i,j,ans;/*

         ^
robot.cpp:23:11: warning: unused variable 'k' [-Wunused-variable]
     int n,k,i,j,ans;/*

           ^
robot.cpp:23:13: warning: unused variable 'i' [-Wunused-variable]
     int n,k,i,j,ans;/*

             ^
robot.cpp:23:15: warning: unused variable 'j' [-Wunused-variable]
     int n,k,i,j,ans;/*

               ^
robot.cpp:23:17: warning: unused variable 'ans' [-Wunused-variable]
     int n,k,i,j,ans;/*

                 ^
robot.cpp:34:11: warning: unused variable 'mod' [-Wunused-variable]
 const int mod=64997;

           ^
robot.cpp:36:5: warning: unused variable 'dp' [-Wunused-variable]
 int dp[3][2801];

     ^
robot.cpp:87:1: error: expected '}' at end of input
 }

 ^

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