Jump to content
Main menu
Main menu
move to sidebar
hide
Navigation
Main page
Recent changes
Random page
Help about MediaWiki
Bitnami MediaWiki
Search
Search
Create account
Log in
Personal tools
Create account
Log in
Pages for logged out editors
learn more
Contributions
Talk
Editing
1708 - Cuburi 3
Page
Discussion
English
Read
Edit
Edit source
View history
Tools
Tools
move to sidebar
hide
Actions
Read
Edit
Edit source
View history
General
What links here
Related changes
Special pages
Page information
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
Ionuţ a învăţat la şcoală să lucreze cu numere mari. El are la dispoziţie un şir de <code>N</code> numere naturale nenule. Din fiecare număr el şterge exact trei cifre, fără să schimbe ordinea cifrelor rămase, astfel încât să obţină cel mai mic număr natural nenul posibil. De exemplu, din numărul <code>20731049</code> se obţine numărul <code>20049</code>, iar din numărul <code>13004</code> se obţine numărul <code>10</code>. Înlocuind fiecare număr citit cu numărul obţinut prin operaţia de mai sus, Ionuţ obţine un nou şir şi scrie termenii acestuia pe feţele unor cuburi astfel: primele şase numere din şir le scrie pe primul cub şi îl notează pe acesta cu <code>1</code>, următoarele şase numere din şir le scrie pe un alt cub pe care îl notează cu <code>2</code> ş.a.m.d. Aceste cuburi au fost distribuite în piramide după modelul din figura. Piramidele au fost numerotate cu numere naturale consecutive. Piramida cu numărul de ordine <code>1</code> este formată numai din cubul cu numărul de ordine <code>1</code> şi are un singur nivel, piramida cu numărul de ordine <code>2</code> are pe primul nivel cuburile <code>2</code>, <code>3</code> şi <code>4</code> iar pe ultimul nivel cubul <code>5</code> ş.a.m.d. Două niveluri alăturate în cadrul unei piramide diferă prin exact două cuburi. Primul nivel al unei piramide conţine cu două cuburi mai mult decât primul nivel al piramidei precedente. Piramida se consideră completă dacă pe ultimul nivel are un singur cub. = Cerința = Scrieţi un program care citeşte numerele naturale nenule <code>N</code> şi <code>K</code>, apoi cele <code>N</code> numere naturale ce fac parte din şirul iniţial, şi determină: a) Numărul de piramide complete construite de Ionuţ. b) Numerele scrise pe cuburile din primele <code>K</code> piramide. = Date de intrare = Fişierul <code>cuburi.in</code> are două linii: prima linie conţine două numere naturale, <code>N</code> şi <code>K</code>, iar a doua linie conţine <code>N</code> numere naturale. Pe fiecare linie a fişierului numerele sunt separate prin câte un spaţiu. = Date de ieșire = Fişierul <code>cuburi.out</code> are două linii: prima linie conţine numărul de piramide complete care au fost construite, iar a doua linie conţine toate numerele scrise pe cuburile ce formează primele <code>K</code> piramide. Numerele sunt scrise separate prin câte un spaţiu, în ordinea apariţiei lor în şirul nou obţinut. = Restricții și precizări = * <code>6 ≤ N ≤ 100000</code> * Se garantează că se pot construi cel puţin <code>K</code> piramide complete. * Cele <code>N</code> numere naturale de pe a doua linie a fişierului de intrare au minimum <code>4</code> cifre şi maximum <code>9</code> cifre. = Exemplu: = <code>cuburi.in</code> 31 2 18250 9280 18250 953805 20800 6040065 24208 4405 8794 1720 98886 96400 45544 8560056 36055 60400 80200 11560 36475 26992 68320 69400 20296 72640 34048 57700 66520 47440 91232 26080 90280 <code>cuburi.out</code> 2 10 2 10 305 20 4005 20 4 4 1 86 40 44 5005 30 40 20 10 34 22 20 40 20 20 30 50 20 40 12 20 == Încărcare soluție == === Lipește codul aici === <syntaxhighlight lang="python" line="1"> import math def nrmin(x, nrc): v = [int(digit) for digit in str(x)] Min = v[0] imin = 0 for i in range(4): if v[i] < Min and v[i] != 0: Min = v[i] imin = i nr = Min in_index = imin + 1 sf = 4 while sf < nrc: Min = v[in_index] imin = in_index for i in range(in_index, sf + 1): if v[i] < Min: Min = v[i] imin = i nr = nr * 10 + Min in_index = imin + 1 sf += 1 return nr def main(): with open("cuburi.in", "r") as stdin, open("cuburi.out", "w") as stdout: n, k = map(int, stdin.readline().split()) nr = sum(i * i * 6 for i in range(1, k + 1)) w = [] nrpir = 0 s = 0 for i in range(1, n + 1): x = int(stdin.readline()) nrc = int(math.log10(x)) + 1 if i % 6 == 0 and math.sqrt(i // 6) == int(math.sqrt(i // 6)): s += i if s <= n: nrpir += 1 if i <= nr: w.append(nrmin(x, nrc)) stdout.write(f"{nrpir}\n") for num in w: stdout.write(f"{num} ") stdout.write("\n") if __name__ == "__main__": main() </syntaxhighlight>
Summary:
Please note that all contributions to Bitnami MediaWiki may be edited, altered, or removed by other contributors. If you do not want your writing to be edited mercilessly, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource (see
Bitnami MediaWiki:Copyrights
for details).
Do not submit copyrighted work without permission!
Cancel
Editing help
(opens in new window)
Toggle limited content width