Detalii evaluare #50877488

Rezumat problemă

#4663 zid1

Fascinată de cultura chineză și Marele Zid Chinezesc, Andra s-a hotărât să își construiască propriul zid în miniatură, de înălțime N și lățime M, din piese roșii și galbene pe care le deține. Ea are la dispoziție un număr nelimitat de piese cu lățimea de o unitate și toate înălțimile posibile. Piesele roșii (hóng) au înălțimea impară (1, 3, 5, ...), pe când piesele galbene (huáng) au înălțimea pară (2, 4, 6, ...). Piesele nu pot fi rotite și pot fi plasate doar pe verticală. Deoarece culoarea galbenă este considerată cea mai prestigioasă în cultura chineză, Andra vrea ca suma lungimilor tuturor pieselor galbene ce alcătuiesc zidul să fie egală cu un număr K, special ales astfel încât să aducă noroc. Mai mult de atât, ea se întreabă în câte moduri poate construi zidul astfel încât această condiție să fie respectată. Date fiind N, M și K, determinați numărul de moduri de a construi zidul în condițiile date.

Detalii

Problema zid1 Operații I/O zid.in/zid.out
Limita timp 1 secunde Limita memorie Total: 128 MB / Stivă 8 MB
Id soluție #50877488 Utilizator Andrei Visalon (Prekzursil)
Fișier zid1.cpp Dimensiune 2.49 KB
Data încărcării 11 Mai 2024, 20:14 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

zid1.cpp:6:22: warning: missing terminating ' character [enabled by default]
 #define mod 1'000'000'007

                      ^
zid1.cpp:48:49: warning: multi-character character constant [-Wmultichar]
             dp[j]=(1LL*dp[j]+1LL*sp1[i-1][j/2])%mod;

                                                 ^
zid1.cpp:48:13: error: missing terminating ' character
             dp[j]=(1LL*dp[j]+1LL*sp1[i-1][j/2])%mod;

             ^
zid1.cpp:51:57: warning: multi-character character constant [-Wmultichar]
                 dp[j]=(1LL*dp[j]+1LL*sp2[i-2][(j-2)/2])%mod;

                                                         ^
zid1.cpp:51:17: error: missing terminating ' character
                 dp[j]=(1LL*dp[j]+1LL*sp2[i-2][(j-2)/2])%mod;

                 ^
zid1.cpp:55:59: warning: multi-character character constant [-Wmultichar]
                 sp1[i][j/2]=(1LL*sp1[i-2][j/2]+1LL*dp[j])%mod;

                                                           ^
zid1.cpp:55:17: error: missing terminating ' character
                 sp1[i][j/2]=(1LL*sp1[i-2][j/2]+1LL*dp[j])%mod;

                 ^
zid1.cpp:57:41: warning: multi-character character constant [-Wmultichar]
                 sp1[i][j/2]=(1LL*dp[j])%mod;

                                         ^
zid1.cpp:57:17: error: missing terminating ' character
                 sp1[i][j/2]=(1LL*dp[j])%mod;

                 ^
zid1.cpp:60:63: warning: multi-character character constant [-Wmultichar]
                 sp2[i][j/2]=(1LL*sp2[i-2][(j-2)/2]+1LL*dp[j])%mod;

                                                               ^
zid1.cpp:60:17: error: missing terminating ' character
                 sp2[i][j/2]=(1LL*sp2[i-2][(j-2)/2]+1LL*dp[j])%mod;

                 ^
zid1.cpp:62:41: warning: multi-character character constant [-Wmultichar]
                 sp2[i][j/2]=(1LL*dp[j])%mod;

                                         ^
zid1.cpp:62:17: error: missing terminating ' character
                 sp2[i][j/2]=(1LL*dp[j])%mod;

                 ^
zid1.cpp:87:53: warning: multi-character character constant [-Wmultichar]
                     ll add=(1LL*v[i/2]*1LL*nr[j/2])%mod;

                                                     ^
zid1.cpp:87:21: error: missing terminating ' character
                     ll add=(1LL*v[i/2]*1LL*nr[j/2])%mod;

                     ^
zid1.cpp:88:53: warning: multi-character character constant [-Wmultichar]
                     aux[(i+j)/2]=(aux[(i+j)/2]+add)%mod;

                                                     ^
zid1.cpp:88:21: error: missing terminating ' character
                     aux[(i+j)/2]=(aux[(i+j)/2]+add)%mod;

                     ^
zid1.cpp:105:48: warning: multi-character character constant [-Wmultichar]
                 ll add=(1LL*v[i/2]*1LL*v[j/2])%mod;

                                                ^
zid1.cpp:105:17: error: missing terminating ' character
                 ll add=(1LL*v[i/2]*1LL*v[j/2])%mod;

                 ^
zid1.cpp:106:49: warning: multi-character character constant [-Wmultichar]
                 aux[(i+j)/2]=(aux[(i+j)/2]+add)%mod;

                                                 ^
zid1.cpp:106:17: error: missing terminating ' character
                 aux[(i+j)/2]=(aux[(i+j)/2]+add)%mod;

                 ^
zid1.cpp: In function 'int main()':
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:48:49: note: in expansion of macro 'mod'
             dp[j]=(1LL*dp[j]+1LL*sp1[i-1][j/2])%mod;

                                                 ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:51:57: note: in expansion of macro 'mod'
                 dp[j]=(1LL*dp[j]+1LL*sp2[i-2][(j-2)/2])%mod;

                                                         ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:55:59: note: in expansion of macro 'mod'
                 sp1[i][j/2]=(1LL*sp1[i-2][j/2]+1LL*dp[j])%mod;

                                                           ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:57:41: note: in expansion of macro 'mod'
                 sp1[i][j/2]=(1LL*dp[j])%mod;

                                         ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:60:63: note: in expansion of macro 'mod'
                 sp2[i][j/2]=(1LL*sp2[i-2][(j-2)/2]+1LL*dp[j])%mod;

                                                               ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:62:41: note: in expansion of macro 'mod'
                 sp2[i][j/2]=(1LL*dp[j])%mod;

                                         ^
zid1.cpp:6:14: error: expected ',' or ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:87:53: note: in expansion of macro 'mod'
                     ll add=(1LL*v[i/2]*1LL*nr[j/2])%mod;

                                                     ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:88:53: note: in expansion of macro 'mod'
                     aux[(i+j)/2]=(aux[(i+j)/2]+add)%mod;

                                                     ^
zid1.cpp:6:14: error: expected ',' or ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:105:48: note: in expansion of macro 'mod'
                 ll add=(1LL*v[i/2]*1LL*v[j/2])%mod;

                                                ^
zid1.cpp:6:14: error: expected ';' before '\x303030'
 #define mod 1'000'000'007

              ^
zid1.cpp:106:49: note: in expansion of macro 'mod'
                 aux[(i+j)/2]=(aux[(i+j)/2]+add)%mod;

                                                 ^

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