#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.
ONI 2024, clasele 11-12
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 | |
Fișier | zid1.cpp | Dimensiune | 2.49 KB |
Data încărcării | 11 Mai 2024, 20:14 | Scor / rezultat | Eroare de 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; ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema zid1 face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
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ă.