2290 - Oglindite: Difference between revisions

From Bitnami MediaWiki
Pop Giulia (talk | contribs)
Pop Giulia (talk | contribs)
No edit summary
 
Line 1: Line 1:
Sursa: [https://www.pbinfo.ro/probleme/2290/oglindite]
==Cerința==
==Cerința==
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.
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.

Latest revision as of 12:52, 20 May 2023

Sursa: [1]

Cerința[edit]

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]

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

Date de ieșire[edit]

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

Restricții și precizări[edit]

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

Exemplu:[edit]

Intrare

4 127 964 801 601 Ieșire

601

Explicație[edit]

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]

<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>