#1061
Cifru1
Costel a descoperit într-o debara servieta cu cifru a tatălui său. Cifrul este compus din 4
discuri metalice pe care sunt inscripţionate cifrele de la 0
la 9
. Fiecare disc se poate mişca individual, de sus în jos sau de jos în sus, formându-se combinaţii de cifre. De multe ori, datorită comodităţii, combinaţia ce permite deschiderea servietei este formată numai din cifre identice: 0000
, 1111
etc.
Costel îşi imaginează un cifru compus din N
discuri metalice, fiecare având inscripţionate cifrele de la 0
la 9
, fiecare putând fi deplasat în cele două direcţii specificate anterior. Prin mutare Costel înţelege deplasarea unui disc în sus sau în jos, cu o singură poziţie, adică deplasarea discului până la cifra precedentă, respectiv următoare celei curente.
Realizaţi un program care, cunoscând poziţia iniţială a fiecărui disc dintre cele N
discuri ale cifrului, determină şi afişează:
a) cifra cea mai mare care apare pe discurile cifrului în forma iniţială;
b)
b1) numărul minim de mutări necesare pentru ca numărul obţinut pe cifru să fie compus numai din cifre identice, număr necesar deschiderii servietei;
b2) cifra cea mai mică ce se poate obţine în urma efectuării numărului minim de mutări determinat;
b3) numărul de combinaţii formate din cifre identice, care se poate obţine în urma efectuării numărului minim de mutări determinat.
OJI 2012, Clasa a VI-a
Problema | Cifru1 | Operații I/O |
cifru1.in /cifru1.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 2 MB
/
Stivă 2 MB
|
Id soluție | #49763532 | Utilizator | |
Fișier | cifru1.cpp | Dimensiune | 872 B |
Data încărcării | 14 Martie 2024, 11:01 | Scor / rezultat | Eroare de compilare |
cifru1.cpp: In function 'int main()': cifru1.cpp:16:16: error: invalid types 'long long int[int]' for array subscript v[j]=v[j]+min(mutj,muts); ^ cifru1.cpp:16:21: error: invalid types 'long long int[int]' for array subscript v[j]=v[j]+min(mutj,muts); ^ cifru1.cpp:20:18: error: 'j' was not declared in this scope mutj=j-a; ^ cifru1.cpp:22:16: error: invalid types 'long long int[int]' for array subscript v[i]=v[i]+min(mutj,muts); ^ cifru1.cpp:22:21: error: invalid types 'long long int[int]' for array subscript v[i]=v[i]+min(mutj,muts); ^ cifru1.cpp:32:15: error: invalid types 'long long int[int]' for array subscript if(v[i]==mn) ^ cifru1.cpp:34:19: error: invalid types 'long long int[int]' for array subscript mn=v[i]; ^ cifru1.cpp:35:13: error: 'c' was not declared in this scope c=i; ^ cifru1.cpp:36:13: error: 'cnt' was not declared in this scope cnt=0; ^ cifru1.cpp:38:15: error: invalid types 'long long int[int]' for array subscript if(v[i]==mn) ^ cifru1.cpp:40:13: error: 'cnt' was not declared in this scope cnt++; ^ cifru1.cpp:43:27: error: 'c' was not declared in this scope fout << mx << endl << c << endl << cnt; ^ cifru1.cpp:43:40: error: 'cnt' was not declared in this scope fout << mx << endl << c << endl << cnt; ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Cifru1 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ă.