2681 - Invers Max

De la Universitas MediaWiki

Cerința

Se citește un șir de caractere reprezentând o propoziție care conține litere mari și mici ale alfabetului englez, spații, cifre și alte simboluri. În cele ce urmează, considerăm cuvânt orice secvență delimitată de spații ce conține cel puțin o literă.

Se se afișeze șirul citit astfel încât cuvintele de lungime maximă să fie înlocuite cu inversul (oglinditul) lor, restul cuvintelor și aranjarea lor în propoziție să rămână neschimbate.

Date de intrare

Programul citește de la tastatură șirul de caractere.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: " Datele de intrare corespund restrictiilor impuse", apoi pe un rand nou va afișa șirul transformat în conformitate cu cerința. În caz contrar, se va afișa mesajul:" Datele de intrare nu corespund restrictiilor impuse".

Restricții și precizări

șirul dat va conține maximum 255 de caractere

Exemplu 1

Intrare
Mara 23a4 1234 %&a* %&*( are mere
Ieșire
Datele introduse corespund restricțiilor impuse.
araM 4a32 1234 *a&% %&*( are erem


Exemplu 2

Intrare
14567898765 esdrtyfugihk esdfghuikjnbvcvbhjhg x3456789098765434567&&&&&&&&&&&&%%%%%%%%%%%%% %%^%%%/############@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ fds vcxssdcv @@@@@@@@@@@@@v rdedf @@%$dvbgfrdcvc%^&&&&&&&&&&&&&&&&&&& 212345678987654323456787654345678765434567865432345cvb 67865432345 6543456 765434567654323456765432 34567u8iuygfcvb njkjhgfvcxsdrfthnbvcxdrtyhbvf gfghjkhbvcxc vdchdvfvf f
Ieșire
Datele de intrare nu corespund restricțiilor impuse.


Rezolvare

# 2681 InversMax

def validare(cuvinte):          # functia de verificare a datelor de intrare
    if len(cuvinte) > 255:
        raise ValueError
    # daca datele de intrare nu corespund, ridicam eroarea ValueError
    print("Datele de intrare corespund restrictiilor impuse")
    return True


def inversmax(cuvinte):         # functia de rezolvare
    cuvinte = cuvinte.split()   # impartim propozitia intr o lista de cuvinte
    maxim = -1                  # aflam lungimea maxima

    for cuvant in cuvinte:
        contine_litera = False
        for litera in cuvant:
            if ('a' <= litera <= 'z') or ('A' <= litera <= 'Z'):
                contine_litera = True
                break
        # pentru a fi cuvant, trebuie sa contina litera, daca lungimea e si mai mare ca maximul, updatam maximul
        if contine_litera is True and maxim < len(cuvant):
            maxim = len(cuvant)

    for cuvant in cuvinte:
        contine_litera = False
        for litera in cuvant:
            if ('a' <= litera <= 'z') or ('A' <= litera <= 'Z'):
                contine_litera = True
                break
        # daca e cuvant si de lungime maxima, il afisam invers
        if contine_litera is True and maxim == len(cuvant):
            print(cuvant[::-1], end=" ")
        else:   # altfel afisam asa cum e
            print(cuvant, end=" ")


if __name__ == '__main__':

    # din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam
    try:
        text = input(f"Introduceti textul ")        # citirea textului
        validare(text)                              # apelul functiei de validare
        inversmax(text)                             # apelul functiei de rezolvare

    except ValueError:
        print("Datele de intrare nu corespund restrictiilor impuse")
    except IndexError:
        print("Datele de intrare nu corespund restrictiilor impuse")