3269 - Reverse Words: Difference between revisions

From Bitnami MediaWiki
 
Line 47: Line 47:
     return s
     return s


def main():
if __name__ == "__main__":
     s = "dubai dubai viata ca in rai"
     s = "dubai dubai viata ca in rai"
     print("Input: ", s)
     print("Input: ", s)
     print("Output:", ReverseWords(s))
     print("Output:", ReverseWords(s))


if __name__ == "__main__":
 
     main()
      





Latest revision as of 18:21, 6 May 2023

Cerință[edit | edit source]

Scrieți funcția care primește ca parametru un șir s format din cuvinte separate prin câte un spațiu. Cuvintele sunt formate doar din litere mici. Funcția va returna, tot prin intermediul parametrului s, cuvintele în ordine inversă, separate tot prin câte un spațiu.

Date de intrare[edit | edit source]

Un șir de caractere "s" de cel mult 800.000 de lungime și conține cel puțin două cuvinte. Șirul "s" conține cuvinte formate doar din litere mici și sunt separate prin exact un spațiu.

Date de ieșire[edit | edit source]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." Programul va afișa șirul "s" modificat astfel încât cuvintele să fie în ordine inversă, separate tot prin câte un spațiu. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."

Restricții de precizări[edit | edit source]

  • Lungimea șirului s este de cel mult 800.000 și conține cel puțin două cuvinte
  • șirul poate conține cuvinte de o literă
  • cuvintele din șir sunt separate prin exact un spațiu
  • șirul este indexat de la 0, începe cu o literă și se termină cu o literă


Exemplu[edit | edit source]

Exemplul 1[edit | edit source]

Intrare
"dubai dubai viata ca in rai"
Ieșire
"rai in ca viata dubai dubai"

Rezolvare[edit | edit source]

Rezolvare var. 1[edit | edit source]

<syntaxhighlight lang="python" line="1" start="1">

def validate_input(s):

   # Verifică lungimea șirului și conținutul acestuia
   if len(s) > 800000:
       return False
   words = s.split()
   if len(words) < 2:
       return False
   for word in words:
       if not word.isalpha() or not word.islower():
           return False
   return True

def ReverseWords(s):

   if not validate_input(s):
       return None
   words = s.split()
   words.reverse()
   s = ' '.join(words)
   return s

if __name__ == "__main__":

   s = "dubai dubai viata ca in rai"
   print("Input: ", s)
   print("Output:", ReverseWords(s))




</syntaxhighlight>

Explicație[edit | edit source]

Funcția validate_input verifică dacă inputul respectă restricțiile impuse în cerință, și returnează True dacă acesta este valid, sau False în caz contrar.

Funcția ReverseWords primește un șir de caractere s, și folosește funcția validate_input pentru a verifica dacă inputul este valid. Dacă inputul este valid, funcția separă cuvintele din șir, inversează ordinea cuvintelor, și le recompune într-un nou șir, care este returnat. Dacă inputul nu este valid, funcția returnează None.

Blocul main apelează funcția ReverseWords pentru un șir dat, și afișează inputul și outputul funcției.