1159 - Smen: Difference between revisions

From Bitnami MediaWiki
No edit summary
No edit summary
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
==Cerința==
==Cerința==
Se dă un șir <code>V</code>. Știind <code>V0 = 3</code> și regula de formare a șirului:
Se dă un șir <code>V</code>. Știind <code>V<sub>0</sub> = 3</code> și regula de formare a șirului:


<code>V<sub>i</sub> = ([V<sub>i-1</sub>*V<sub>i-1</sub> / (i + 2)] +  V<sub>i-1</sub> * i + i + 1) % 666013</code>.
<code>V<sub>i</sub> = ([V<sub>i-1</sub>*V<sub>i-1</sub> / (i + 2)] +  V<sub>i-1</sub> * i + i + 1) % 666013</code>.
Line 23: Line 23:
:10000000
:10000000
;Ieșire
;Ieșire
:Datele de intrare corespund restricțiilor impuse.
:22230
:22230


Line 29: Line 30:
:21345670
:21345670
;Ieșire
;Ieșire
:Date de intrare gresite!
:Datele de intrare nu corespund restricțiilor impuse.


==Rezolvare==
==Rezolvare==
<syntaxhighlight lang="python" line="1">
<syntaxhighlight lang="python" line="1">
#1159 Smen
#1159 Smen


def conditii(n):
def conditii(n):
Line 40: Line 40:




def main():
def smen(n):
     n = int(input())
     # v_n = valoarea de la pasul n
 
     # v_i = valoarea de la pasul i
     if not conditii(n):
     # Primul termen al șirului este 3
        return print("Datele de intrare nu corespund restricțiilor impuse.")
     print("Datele de intrare corespund restricțiilor impuse.")
 
     v_n, v_i = 3, 0
     v_n, v_i = 3, 0
     for i in range(n+1):
     for i in range(n + 1):
         v_i = ((v_n * v_n // (i+2)) + v_n * i + i + 1) % 666013
        # Formula de recurență, conform cerinței
         v_i = ((v_n * v_n // (i + 2)) + v_n * i + i + 1) % 666013
        # Înlocuim v_n cu v_i pentru a putea calcula următorul termen
         v_n = v_i
         v_n = v_i


    # Afisăm al n-lea termen
     print(v_i)
     print(v_i)




if __name__ == "__main__":
if __name__ == "__main__":
     main()
     n = int(input())
 
    if not conditii(n):
        print("Datele de intrare nu corespund restricțiilor impuse.")
    else:
        print("Datele de intrare corespund restricțiilor impuse.")
        smen(n)


</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 15:17, 5 May 2023

Cerința[edit | edit source]

Se dă un șir V. Știind V0 = 3 și regula de formare a șirului:

Vi = ([Vi-1*Vi-1 / (i + 2)] + Vi-1 * i + i + 1) % 666013.

să se determine al n-lea termen al șirului. (unde [x] reprezintă partea întreagă a numărului x)

Date de intrare[edit | edit source]

Fișierul de intrare smen.in conține numărul n.

Date de ieșire[edit | edit source]

Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse."

Pe următorul rând se va afișa al n-lea termen al șirului.

În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse."

Restricții și precizări[edit | edit source]

  • 1 ≤ n ≤ 20.000.000

Exemplu 1[edit | edit source]

Intrare
10000000
Ieșire
Datele de intrare corespund restricțiilor impuse.
22230

Exemplu 2[edit | edit source]

Intrare
21345670
Ieșire
Datele de intrare nu corespund restricțiilor impuse.

Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line="1">

  1. 1159 Smen

def conditii(n):

   return 1 <= n <= 20_000_000


def smen(n):

   # v_n = valoarea de la pasul n
   # v_i = valoarea de la pasul i
   # Primul termen al șirului este 3
   v_n, v_i = 3, 0
   for i in range(n + 1):
       # Formula de recurență, conform cerinței
       v_i = ((v_n * v_n // (i + 2)) + v_n * i + i + 1) % 666013
       # Înlocuim v_n cu v_i pentru a putea calcula următorul termen
       v_n = v_i
   # Afisăm al n-lea termen
   print(v_i)


if __name__ == "__main__":

   n = int(input())
   if not conditii(n):
       print("Datele de intrare nu corespund restricțiilor impuse.")
   else:
       print("Datele de intrare corespund restricțiilor impuse.")
       smen(n)

</syntaxhighlight>