2290 - Oglindite

From Bitnami MediaWiki

Sursa: [1]

Cerința[edit | edit source]

Se dau n numere naturale. Afișați numărul pentru care diferența în valoare absolută dintre el și oglinditul său este minimă. Dacă există mai multe asemenea numere, afișați-l pe cel mai mic.

Date de intrare[edit | edit source]

Programul citește de la tastatură numărul n, iar apoi n numere naturale.

Date de ieșire[edit | edit source]

Programul va afișa pe ecran numărul determinat x.

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

1 ≤ n ≤ 1000 cele n numere citite vor fi mai mici decât 1.000.000.000

Exemplu:[edit | edit source]

Intrare

4 127 964 801 601 Ieșire

601

Explicație[edit | edit source]

oglinditul lui 127 este 721, iar diferența este 594 oglinditul lui 964 este 469, iar diferența este 495 oglinditul lui 801 este 108, iar diferența este 693 oglinditul lui 601 este 106, iar diferența este 495 Diferența minimă este 495 și se obține pentru 601

Solutie[edit | edit source]

<syntaxhighlight lang="python" line> n = int(input()) min_diff = float('inf') found_num = float('inf')

for i in range(n):

   num = int(input())
   reversed_num = int(str(num)[::-1])
   diff = abs(num - reversed_num)
   if diff < min_diff or (diff == min_diff and num < found_num):
       min_diff = diff
       found_num = num

print(found_num) </syntaxhighlight>