3269 - Reverse Words: Difference between revisions
Vardai Erwin (talk | contribs) |
Vardai Erwin (talk | contribs) |
||
(One intermediate revision by the same user not shown) | |||
Line 18: | Line 18: | ||
==Exemplu== | ==Exemplu== | ||
=== Exemplul 1=== | === Exemplul 1=== | ||
;Intrare | |||
:"dubai dubai viata ca in rai" | |||
;Ieșire | |||
:"rai in ca viata dubai dubai" | |||
==Rezolvare== | ==Rezolvare== | ||
Line 46: | Line 47: | ||
return s | return s | ||
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)) | ||
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.