#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 | #54022100 | Utilizator | |
Fișier | cifru1.cpp | Dimensiune | 761 B |
Data încărcării | 18 Noiembrie 2024, 09:41 | Scor / rezultat | Eroare de compilare |
cifru1.cpp: In function 'int main()': cifru1.cpp:22:9: warning: the address of 'v' will always evaluate as 'true' [-Waddress] if(v) ^ cifru1.cpp:9:41: warning: unused variable 'difmin' [-Wunused-variable] int n,nrcifmax=0,summin=0,summaxx=0,difmin=0,difmax=0,nrmin=9999,cnt=0; ^ cifru1.cpp:9:50: warning: unused variable 'difmax' [-Wunused-variable] int n,nrcifmax=0,summin=0,summaxx=0,difmin=0,difmax=0,nrmin=9999,cnt=0; ^ cifru1.cpp:9:70: warning: variable 'cnt' set but not used [-Wunused-but-set-variable] int n,nrcifmax=0,summin=0,summaxx=0,difmin=0,difmax=0,nrmin=9999,cnt=0; ^ cifru1.cpp: At global scope: cifru1.cpp:34:5: error: 'cout' does not name a type cout<<difmax<<endl; ^ cifru1.cpp:35:5: error: expected unqualified-id before 'if' if(cnt==1) ^ cifru1.cpp:37:5: error: expected unqualified-id before 'else' else ^ cifru1.cpp:39:5: error: 'cout' does not name a type cout<<difmin; ^ cifru1.cpp:42:1: error: expected declaration before '}' token } ^
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ă.