2739 - Sir Platou: Difference between revisions

From Bitnami MediaWiki
No edit summary
Line 37: Line 37:
== Rezolvare ==
== Rezolvare ==
<syntaxhighlight lang="python3" line="1">
<syntaxhighlight lang="python3" line="1">
def gaseste_secvente(input_str):
def detecteaza_secvente(sir):
     cuvinte = input_str.split()
     cuvinte = sir.split()
 
     secvente_maxime = []
     secvente_maxime = []
     secventa_curenta = [cuvinte[0]]
      
 
    for i in range(len(cuvinte) - 1):
    for i in range(1, len(cuvinte)):
        secventa_curenta = [cuvinte[i]]
        cuvant_curent = cuvinte[i]
        for j in range(i + 1, len(cuvinte)):
        cuvant_anterior = cuvinte[i - 1]
            if cuvinte[j][0] == cuvinte[i][-1]:
 
                secventa_curenta.append(cuvinte[j])
        if cuvant_anterior[-1] == cuvant_curent[0]:
            else:
            secventa_curenta.append(cuvant_curent)
                 break
        else:
            if len(secventa_curenta) >= 2:
                 secvente_maxime.append(secventa_curenta)
            secventa_curenta = [cuvant_curent]


    if len(secventa_curenta) >= 2:
        if len(secventa_curenta) > 1:
        secvente_maxime.append(secventa_curenta)
            secvente_maxime.append(secventa_curenta)
   
    return secvente_maxime if secvente_maxime else -1


    if not secvente_maxime:
# Citire șir de la tastatură
        print("-1")
sir_intrare = input("Introduceti sirul de caractere: ")
    else:
        for secventa in secvente_maxime:
            print(" ".join(secventa))


# Citirea șirului de caractere de la tastatură
# Detectare și afișare secvențe
input_str = input("Introduceți șirul de caractere: ")
rezultat = detecteaza_secvente(sir_intrare)
if rezultat == -1:
    print(-1)
else:
    for secventa in rezultat:
        print(" ".join(secventa))


# Găsirea și afișarea secvențelor de lungime maximă
gaseste_secvente(input_str)


</syntaxhighlight>
</syntaxhighlight>

Revision as of 10:49, 27 December 2023

Cerinta

Se dă un șir de caractere care conține cuvinte. Cuvintele sunt formate din litere mici ale alfabetului englez și sunt separate prin unul sau mai multe spații.

Determinați secvențele de cuvinte de lungime maximă cu proprietatea că fiecare cuvânt din secvență, cu excepția ultimului, se termină cu litera de început a cuvântului următor. Secvențele au minim 2 cuvinte și se afișează în ordinea în care apar în șir.


Fiecare secvență determinată va fi afișată pe câte o linie a ecranului, cuvintele dintr-o secvență fiind separate prin atâtea spații cât sunt între ele în șir. Dacă nu există nicio astfel de secvență se va afișa -1.

Date de intrare

Programul citește de la tastatură un șir de caractere.

Date de iesire

Programul va afișa pe ecran secvențele de lungime maximă care îndeplinesc cerința, fiecare pe câte o linie, sau -1 dacă nu există nicio astfel de cerință.

Restrictii si precizari

  • șirul dat conține maximum 255 de caractere

Exemplul 1

Intrare
ab bc cd ef fg gh
Iesire
Datele introduse corespund restrictiilor impuse
ab bc cd
ef fg gh

Exemplul 2

Intrare
12 AB cD 0 75
Iesire
Datele introduse nu corespund restrictiilor impuse


Rezolvare

<syntaxhighlight lang="python3" line="1"> def detecteaza_secvente(sir):

   cuvinte = sir.split()
   secvente_maxime = []
   
   for i in range(len(cuvinte) - 1):
       secventa_curenta = [cuvinte[i]]
       for j in range(i + 1, len(cuvinte)):
           if cuvinte[j][0] == cuvinte[i][-1]:
               secventa_curenta.append(cuvinte[j])
           else:
               break
       if len(secventa_curenta) > 1:
           secvente_maxime.append(secventa_curenta)
   
   return secvente_maxime if secvente_maxime else -1
  1. Citire șir de la tastatură

sir_intrare = input("Introduceti sirul de caractere: ")

  1. Detectare și afișare secvențe

rezultat = detecteaza_secvente(sir_intrare) if rezultat == -1:

   print(-1)

else:

   for secventa in rezultat:
       print(" ".join(secventa))


</syntaxhighlight>