2673 - Swap Cuv

From Bitnami MediaWiki
Revision as of 17:31, 25 December 2023 by Hotico Iulia Denisa (talk | contribs) (→‎Exemplu 2)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Cerinţa[edit | edit source]

Se dă un şir de caractere care conține cuvinte formate din litere mici și mari ale alfabetului englez. Cuvintele sunt separate prin orice caractere imprimabile care nu sunt litere (cu codurile ASCII mai mari sau egale cu 32). Să se afișeze cuvintele pe cate o linie în felul următor:

Primul
Ultimul
Al Doilea
Penultimul
...

Date de intrare[edit | edit source]

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

Date de ieșire[edit | edit source]

Programul va afișa pe ecran cate o linie cuvintele în funcție de cerintă.

Restricţii şi precizări[edit | edit source]

  • propoziția va conține cel mult 255 de caractere

Exemplul 1[edit | edit source]

Intrare
divide and conquer / devide et impera.
Iesire
Datele de intrare corespund restrictiilor impuse
divide
impera
and
et
conquer
devide


Exemplul 2[edit | edit source]

Intrare
Loremipsumdolorsitamet,consecteturadipiscingelit.Nullafacilisi.Vestibulumeuismodnequeeumetusrhoncus,neciaculispurussollicitudin.Quisquecondimentum,lacusidsuscipitvestibulum,odiosemegestasnunc,velaliquetpuruseratnecelit.Nullamelementumleoacorcicongue,infringillanisleuismod.Sedaliquet,elit eupellentesqueaccumsanjusitocursuslacus,idhendreritnisl.
Iesire
Datele de intrare nu corespund restrictiilor impuse


Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line> import re

def main():

   # Citirea șirului de caractere de la tastatură
   sir = input().strip()
   # Verifică dacă șirul respectă restricțiile
   if len(sir) > 255:
       print("Datele de intrare nu corespund restrictiilor impuse")
       return
   # Afișarea mesajului de confirmare
   print("Datele de intrare corespund restrictiilor impuse")
   # Separarea cuvintelor din șir
   cuvinte = re.findall(r'\b\w+\b', sir)
   # Afișarea cuvintelor în ordinea cerută
   i = 0
   j = len(cuvinte) - 1
   while i <= j:
       if i == j:
           print(cuvinte[i])
       else:
           print(cuvinte[i])
           print(cuvinte[j])
       i += 1
       j -= 1


if __name__ == "__main__":

   main()

</syntaxhighlight>