#1730
Sstabil
Numim număr sstabil orice număr natural care este format dintr-o singură cifră sau care are suma oricăror două cifre vecine strict mai mare decât nouă.
Asupra oricărui număr care nu este sstabil se pot efectua operaţii de înlocuire a oricăror două cifre vecine care au suma strict mai mică decât zece cu o cifră egală cu suma lor.
Operaţiile de înlocuire pot fi aplicate, în acelaşi condiţii, şi asupra numerelor rezultate după fiecare înlocuire, de câte ori este nevoie, până când se obţine un număr sstabil.
De exemplu, 291
este număr sstabil deoarece 2+9>9
şi 9+1>9
, iar 183
nu este sstabil pentru că 1+8<10
. Din numărul 2453
, efectuând o singură înlocuire, putem obţine 653
sau 293
(număr sstabil) sau 248
. Numărul 653
, nefiind sstabil, permite o nouă operaţie de înlocuire, obţinând astfel numărul 68
, care este sstabil. Analog, din numărul 248
se poate obţine numărul sstabil 68
.
Scrieţi un program care să determine cel mai mare număr natural sstabil care se poate obţine dintr-un număr natural dat, aplicând una sau mai multe operaţii de înlocuire de tipul menţionat.
Problema | Sstabil | Operații I/O |
sstabil.in /sstabil.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 16 MB
/
Stivă 4 MB
|
Id soluție | #54963777 | Utilizator | |
Fișier | sstabil.cpp | Dimensiune | 746 B |
Data încărcării | 13 Decembrie 2024, 19:13 | Scor / rezultat | 100 puncte |
sstabil.cpp: In function 'int main()': sstabil.cpp:6:33: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen("sstabil.in","r",stdin); ^ sstabil.cpp:7:35: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen("sstabil.out","w",stdout); ^ sstabil.cpp:8:18: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d\n",&n); ^ sstabil.cpp:10:20: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d",&a[i]); ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | OK. | 10 | 10 | ||
2 | 0 secunde | OK. | 10 | 10 | ||
3 | 0 secunde | OK. | 10 | 10 | ||
4 | 0 secunde | OK. | 10 | 10 | ||
5 | 0.004 secunde | OK. | 10 | 10 | ||
6 | 0.012 secunde | OK. | 10 | 10 | ||
7 | 0.024 secunde | OK. | 10 | 10 | ||
8 | 0.052 secunde | OK. | 10 | 10 | ||
9 | 0.132 secunde | OK. | 10 | 10 | ||
10 | 0 secunde | OK. | 10 | 10 | ||
Punctaj total | 100 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Sstabil 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ă.