1945 - Benzinarii

De la Universitas MediaWiki

Sursa: [1]


Cerinţa

Gigel, mare pasionat de jocuri merge cu tatăl său în excursie. Pe drum acesta adoarme și devine personaj principal într-o cursă de mașini. În visul său este pilot de formula 1 în jocul Need for Speed! Observă că benzina e pe sfârșite! Trebuie să alimenteze urgent de la o benzinărie dar acestea “apar” numai când kilometrajul mașinii este un număr palindromic (citit în ambele sensuri este la fel).
Se uită spre kilometraj și trebuie să decidă repede: merge înainte spre următoarea stație de benzină sau se întoarce spre stația de benzină anterioară. Dacă benzinăriile sunt la distanțe egale, Gigel va merge înainte. Dacă kilometrajul mașinii indică deja un număr palindromic, ratează această benzinărie, nemaiputând opri la timp (are viteză mare) și caută o soluție: altă benzinărie.
Atenție, kilometrajul mașinii în momentul sosirii la benzinărie nu este obligatoriu un număr palindromic (de exemplu, când Gigel se întoarce din drum).

Presat de timp, Gigel vă roagă să îl ajutați să găsească distanța minimă până la cea mai apropiată benzinărie (numărul palindromic cel mai apropiat) și cât va indica kilometrajul atunci când va sosi la benzinărie.

Date de intrare

Fișierul de intrare benzinarii.in conține o singură valoare n reprezentând kilometrajul mașinii afișat în momentul în care se uită Gigel spre acesta.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi fișierul de ieșire benzinarii.out va conține o singură linie cu două numere, reprezentând distanța până la cea mai apropiată benzinărie (număr palindromic), respectiv kilometrajul cu care va sosi la benzinărie. În caz contrar, pe ecran se va afișa: "Datele nu au fost introduse corect."

Restricţii şi precizări

  • 1 <= n <= 100.000.000.
  • numerele de pe a doua linie a fișierului de intrare vor fi mai mici decât 1.000.000.000

Exemple

Exemplul 1

benzinarii.in
456
Ecran
Datele sunt introduse corect.
benzinarii.out
2 458

Exemplul 2

benzinarii.in
1998
Ecran
Datele sunt introduse corect.
benzinarii.out
4 2002

Exemplul 3

benzinarii.in
4774
Ecran
Datele sunt introduse corect.
benzinarii.out
110 4884

Rezolvare

# 1945

def este_palindrom(numar):
    return str(numar) == str(numar)[::-1]


def gaseste_benzinarii(n):
    if n < 1 or n > 100000000:
        print("Datele nu au fost introduse corect.")
        return

    print("Datele sunt introduse corect.")

    distanta_minima = float('inf')
    km_benzinarii = 0

    # cautam benzinariile inainte
    for i in range(n+1, 100000001):
        if este_palindrom(i):
            distanta = i - n
            if distanta < distanta_minima:
                distanta_minima = distanta
                km_benzinarii = i
            break

    # cautam benzinariile inapoi
    for i in range(n-1, 0, -1):
        if este_palindrom(i):
            distanta = n - i
            if distanta <= distanta_minima:
                distanta_minima = distanta
                km_benzinarii = i
            break

    print(distanta_minima, km_benzinarii)


if __name__ == '__main__':
    with open('benzinarii.in', 'r') as f:
        n = int(f.readline())
        gaseste_benzinarii(n)

Explicație rezolvare

Funcția este_palindrom primește un număr și returnează True dacă este palindrom și False în caz contrar. Am convertit numărul într-un șir de caractere și l-am comparat cu el însuși inversat (str(numar)[::-1]).

Funcția gaseste_benzinarii primește kilometrajul mașinii n și calculează distanța până la cea mai apropiată benzinărie și kilometrajul la care va ajunge Gigel. Mai întâi verificăm dacă datele sunt introduse corect (în conformitate cu restricțiile din enunț) și apoi căutăm benzinariile înainte și înapoi. Pentru fiecare direcție, am utilizat un ciclu for care parcurge numerele de la kilometrajul mașinii până la 100.000.000 într-un caz și până la 0 în celălalt caz. Pentru fiecare număr verificăm dacă este palindrom și calculăm distanța față de kilometrajul mașinii. Dacă distanța este mai mică decât distanța minimă găsită până acum, actualizăm distanța minimă și kilometrajul benzinăriei.

În funcția main citim kilometrajul mașinii din fișierul de intrare și apelăm funcția gaseste_benzinarii.