2739 - Sir Platou: Difference between revisions

From Bitnami MediaWiki
Pagină nouă: == 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ță deter...
 
 
(2 intermediate revisions by the same user not shown)
Line 3: Line 3:
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.
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.
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.
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 ==
== Date de intrare ==
Line 14: Line 14:
== Date de iesire ==
== 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ță.
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 ==
== Restrictii si precizari ==


*șirul dat conține maximum 255 de caractere
*șirul dat conține maximum '''255''' de caractere


== Exemplul 1 ==
== Exemplul 1 ==
Line 24: Line 24:
:ab  bc  cd ef fg  gh
:ab  bc  cd ef fg  gh
;Iesire
;Iesire
;Datele introduse corespund restrictiilor impuse
:Datele introduse corespund restrictiilor impuse
:ab  bc  cd
:ab  bc  cd
:ef fg  gh
:ef fg  gh
Line 32: Line 32:
:12 AB cD 0 75
:12 AB cD 0 75
;Iesire
;Iesire
;Datele introduse nu corespund restrictiilor impuse
:Datele introduse nu corespund restrictiilor impuse




== 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 = []
   
    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


     secvente_maxime = []
def verifica_rezultat(input_file, output_file):
    secventa_curenta = [cuvinte[0]]
     with open(input_file, "r") as f:
        sir_intrare = f.readline().strip()


     for i in range(1, len(cuvinte)):
     with open(output_file, "r") as g:
         cuvant_curent = cuvinte[i]
         rezultat_asteptat = g.readline().strip()
        cuvant_anterior = cuvinte[i - 1]


        if cuvant_anterior[-1] == cuvant_curent[0]:
    rezultat_program = detecteaza_secvente(sir_intrare)
            secventa_curenta.append(cuvant_curent)
        else:
            if len(secventa_curenta) >= 2:
                secvente_maxime.append(secventa_curenta)
            secventa_curenta = [cuvant_curent]


     if len(secventa_curenta) >= 2:
     if rezultat_program == -1:
         secvente_maxime.append(secventa_curenta)
        rezultat_program_str = "-1"
    else:
         rezultat_program_str = "\n".join([" ".join(secventa) for secventa in rezultat_program])


     if not secvente_maxime:
     if rezultat_program_str == rezultat_asteptat:
         print("-1")
         print("Rezultat corect!")
     else:
     else:
         for secventa in secvente_maxime:
         print("Rezultat incorect!")
            print(" ".join(secventa))
        print("Rezultat așteptat:")
        print(rezultat_asteptat)
        print("Rezultat obținut:")
        print(rezultat_program_str)


# Citirea șirului de caractere de la tastatură
# Verificare rezultat pentru exemplele date
input_str = input("Introduceți șirul de caractere: ")
verifica_rezultat("exemplu1in.txt", "exemplu1out.txt")
verifica_rezultat("exemplu2in.txt", "exemplu2out.txt")


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


</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 12:05, 29 December 2023

Cerinta[edit | edit source]

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[edit | edit source]

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

Date de iesire[edit | edit source]

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[edit | edit source]

  • șirul dat conține maximum 255 de caractere

Exemplul 1[edit | edit source]

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

Exemplul 2[edit | edit source]

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


Rezolvare[edit | edit source]

<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

def verifica_rezultat(input_file, output_file):

   with open(input_file, "r") as f:
       sir_intrare = f.readline().strip()
   with open(output_file, "r") as g:
       rezultat_asteptat = g.readline().strip()
   rezultat_program = detecteaza_secvente(sir_intrare)
   if rezultat_program == -1:
       rezultat_program_str = "-1"
   else:
       rezultat_program_str = "\n".join([" ".join(secventa) for secventa in rezultat_program])
   if rezultat_program_str == rezultat_asteptat:
       print("Rezultat corect!")
   else:
       print("Rezultat incorect!")
       print("Rezultat așteptat:")
       print(rezultat_asteptat)
       print("Rezultat obținut:")
       print(rezultat_program_str)
  1. Verificare rezultat pentru exemplele date

verifica_rezultat("exemplu1in.txt", "exemplu1out.txt") verifica_rezultat("exemplu2in.txt", "exemplu2out.txt")


</syntaxhighlight>