#4838
Lui Fibo îi plac numerele care nu se potrivesc perfect. Recent, acesta a descoperit niște numere mai speciale: el numește un număr x ca fiind antidivizorul unui număr natural nenul k, dacă x este cel mai mic număr natural nenul care nu-l divide pe k. Fie F(k) = x, unde x este antidivizorul lui k. Să se calculeze F(1) + F(2) + ... + F(N) pentru T valori ale lui N.
ONI 2025, clasa a 9-a
| Problema | antidivizor | Operații I/O |
antidivizor.in/antidivizor.out
|
|---|---|---|---|
| Limita timp | 0.2 secunde | Limita memorie |
Total: 512 MB
/
Stivă 128 MB
|
| Id soluție | #61856290 | Utilizator | |
| Fișier | antidivizor.cpp | Dimensiune | 1.17 KB |
| Data încărcării | 12 Decembrie 2025, 11:54 | Scor/rezultat | 100 puncte |
antidivizor.cpp: In function 'long long int answer_query(long long int)': antidivizor.cpp:19:43: warning: array subscript has type 'char' [-Wchar-subscripts] ans += (n / cmmmc[i - 1]) * antidivs[i]; ^ antidivizor.cpp:20:24: warning: array subscript has type 'char' [-Wchar-subscripts] ans -= (n / cmmmc[i]) * antidivs[i]; ^ antidivizor.cpp:20:39: warning: array subscript has type 'char' [-Wchar-subscripts] ans -= (n / cmmmc[i]) * antidivs[i]; ^ antidivizor.cpp:21:22: warning: array subscript has type 'char' [-Wchar-subscripts] } while ( cmmmc[i++] <= n ); ^ antidivizor.cpp: In function 'int main()': antidivizor.cpp:33:32: warning: ignoring return value of 'int fscanf(FILE*, const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] for ( fscanf( fin, "%d", &t ); t > 0; t-- ) { ^ antidivizor.cpp:34:30: warning: ignoring return value of 'int fscanf(FILE*, const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] fscanf( fin, "%lld", &n ); ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0 secunde | OK. | 7 | 7 | ||
| 2 | 0 secunde | OK. | 7 | 7 | ||
| 3 | 0 secunde | OK. | 7 | 7 | ||
| 4 | 0 secunde | OK. | 7 | 7 | ||
| 5 | 0 secunde | OK. | 7 | 7 | ||
| 6 | 0.044 secunde | OK. | 5 | 5 | ||
| 7 | 0.044 secunde | OK. | 5 | 5 | ||
| 8 | 0.044 secunde | OK. | 5 | 5 | ||
| 9 | 0.044 secunde | OK. | 5 | 5 | ||
| 10 | 0.044 secunde | OK. | 6 | 6 | ||
| 11 | 0 secunde | OK. | 3 | 3 | ||
| 12 | 0 secunde | OK. | 4 | 4 | ||
| 13 | 0 secunde | OK. | 4 | 4 | ||
| 14 | 0 secunde | OK. | 4 | 4 | ||
| 15 | 0 secunde | OK. | 4 | 4 | ||
| 16 | 0.092 secunde | OK. | 4 | 4 | ||
| 17 | 0.092 secunde | OK. | 4 | 4 | ||
| 18 | 0.092 secunde | OK. | 4 | 4 | ||
| 19 | 0.092 secunde | OK. | 4 | 4 | ||
| 20 | 0.092 secunde | OK. | 4 | 4 | ||
| Punctaj total | 100 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema antidivizor 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ă.