0629 - Zet

De la Universitas MediaWiki

Enunt

Fie z∈R,z≠0 astfel încât z+1/z=k,k∈N

Cerința

Dându-se k și un număr natural n, se cere:

a) să calculați  z^2 + 1/z^2;

b) să se determine  z^n + 1/z^n.

Date de intrare

Fişierul de intrare zetIN.txt conţine pe prima linie un număr natural p. Pentru toate testele de intrare, numărul p poate avea doar valoarea 1 sau valoarea 2. Pe următoarea linie se află numerele k şi n, cu semnificaţiile din enunţ.

Date de ieșire

p. Dacă valoarea lui p este 1, se va rezolva numai punctul a) din cerință. În acest caz, în fişierul de ieşire zetOUT.txt se va scrie un singur număr natural reprezentând rezultatul calculului cerut la punctul a).

Dacă valoarea lui p este 2, se va rezolva numai punctul b) din cerință. În acest caz, fişierul de ieşire zetOUT.txt va conține un singur număr natural reprezentând rezultatul calculului cerut la punctul b). În cazul în care restricțiile nu sunt îndeplinite, se va afișa mesajul "Datele nu corespund restrictiilor impuse".

Restricții și precizări

  • 2 ≤ k < 30
  • 3 ≤ n ≤ 13
  • Pentru rezolvarea corectă a primei cerinţe se acordă 20 de puncte, iar pentru cerința a doua se acordă 80 de puncte.

Exemplul 1:

zetIN.txt

1
3 5

zetOUT.txt

7

Explicație

p = 1

Exemplul 2:

zetIN.txt

1
313 5

zetOUT.txt

Datele nu corespund restrictiilor impuse

Rezolvare

import math

def genereaza(k, f):
    f[0] = 2
    f[1] = k
    for x in range(2, 14):
        f[x] = k * f[x-1] - f[x-2]

def verifica_restricții(k, n):
    if not (2 <= k < 30) or not (3 <= n <= 13):
        return False
    return True

def principal():
    with open('zetIN.txt', 'r') as intrare:
        cer = int(intrare.readline().strip())
        k, n = map(int, intrare.readline().split())
    f = [0]*16
    if verifica_restricții(k, n):
        genereaza(k, f)
        with open('zetOUT.txt', 'w') as iesire:
            if cer == 1:
                iesire.write(str(f[2]))
            else:
                iesire.write(str(f[n]))
    else:
        with open('zetOUT.txt', 'w') as iesire:
            iesire.write("Datele nu corespund restrictiilor impuse")

if __name__ == "__main__":
    principal()