<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0101_-_Sortare_Cuvinte</id>
	<title>0101 - Sortare Cuvinte - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0101_-_Sortare_Cuvinte"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0101_-_Sortare_Cuvinte&amp;action=history"/>
	<updated>2026-05-01T04:03:26Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://wiki.universitas.ro/index.php?title=0101_-_Sortare_Cuvinte&amp;diff=8073&amp;oldid=prev</id>
		<title>AntalKrisztian: Pagină nouă: == Cerinţa == Să se scrie un program care citește o propoziţie şi afişează cuvintele din propoziţie ordonate alfabetic. == Date de intrare == Fișierul de intrare &#039;&#039;&#039;sortcuvin.txt&#039;&#039;&#039; conține pe prima linie o propoziție alcătuită din litere mici ale alfabetului englez și spații. == Date de ieşire == Fișierul de ieșire &#039;&#039;&#039;sortcuvout&#039;&#039;&#039; va conține cuvintele din propoziție, ordonate alfabetic, fiecare pe câte o linie. == Restricții și precizări == * propozi...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0101_-_Sortare_Cuvinte&amp;diff=8073&amp;oldid=prev"/>
		<updated>2023-12-14T13:20:59Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Cerinţa == Să se scrie un program care citește o propoziţie şi afişează cuvintele din propoziţie ordonate alfabetic. == Date de intrare == Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;sortcuvin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie o propoziție alcătuită din litere mici ale alfabetului englez și spații. == Date de ieşire == Fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;sortcuvout&amp;#039;&amp;#039;&amp;#039; va conține cuvintele din propoziție, ordonate alfabetic, fiecare pe câte o linie. == Restricții și precizări == * propozi...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Cerinţa ==&lt;br /&gt;
Să se scrie un program care citește o propoziţie şi afişează cuvintele din propoziţie ordonate alfabetic.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;sortcuvin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie o propoziție alcătuită din litere mici ale alfabetului englez și spații.&lt;br /&gt;
== Date de ieşire ==&lt;br /&gt;
Fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;sortcuvout&amp;#039;&amp;#039;&amp;#039; va conține cuvintele din propoziție, ordonate alfabetic, fiecare pe câte o linie.&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
* propoziția va conține cel mult &amp;#039;&amp;#039;&amp;#039;250&amp;#039;&amp;#039;&amp;#039; de caractere;&lt;br /&gt;
* fiecare cuvânt din propoziție are cel mult &amp;#039;&amp;#039;&amp;#039;20&amp;#039;&amp;#039;&amp;#039; litere&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; sortcuvin.txt&lt;br /&gt;
 dreptunghiul este un paralelogram cu un unghi drept&lt;br /&gt;
; sortcuvout.txt&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse.&lt;br /&gt;
 cu&lt;br /&gt;
 drept&lt;br /&gt;
 dreptunghiul&lt;br /&gt;
 este&lt;br /&gt;
 paralelogram&lt;br /&gt;
 un&lt;br /&gt;
 un&lt;br /&gt;
 unghi&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; sortcuvin.txt&lt;br /&gt;
 acestcuvantaremaimulteliteredecatestepermis&lt;br /&gt;
; sortcuvout.txt&lt;br /&gt;
 Datele de intrare nu corespund restrictiilor impuse.&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
# functia de validare verifica daca datele de intrare sunt in intervalul specificat&lt;br /&gt;
def validare(propozitie_validare):&lt;br /&gt;
    # verificam daca lungimea propozitiei este in intervalul 0-250&lt;br /&gt;
    if len(propozitie_validare) &amp;lt;= 0 or len(propozitie_validare) &amp;gt; 250:&lt;br /&gt;
        raise ValueError  # ridicam o eroare daca lungimea propozitiei nu este in intervalul 0-250&lt;br /&gt;
    for cuvant_validare in propozitie_validare.split():    # parcurgem lista de cuvinte&lt;br /&gt;
        # verificam daca lungimea cuvantului este mai mica sau egala cu 20&lt;br /&gt;
        if len(cuvant_validare) &amp;gt; 20:&lt;br /&gt;
            raise ValueError&lt;br /&gt;
        # verificam daca cuvantul contine doar litere mici ale alfabetului englezesc&lt;br /&gt;
        if not cuvant_validare.islower():&lt;br /&gt;
            raise ValueError&lt;br /&gt;
        # verificam daca cuvantul contine numere&lt;br /&gt;
        if any(char.isdigit() for char in cuvant_validare):&lt;br /&gt;
            raise ValueError&lt;br /&gt;
    file_out.write(&amp;quot;Datele de intrare corespund restrictiilor impuse.\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# functia sort_words sorteaza cuvintele in functie de ordinea alfabetica&lt;br /&gt;
def sort_words(cuvinte):&lt;br /&gt;
    # sortam cuvintele in functie de ordinea alfabetica&lt;br /&gt;
    cuvinte.sort()&lt;br /&gt;
    return cuvinte&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;#039;__main__&amp;#039;:&lt;br /&gt;
    file_in = open(&amp;quot;sortcuvin.txt&amp;quot;, &amp;quot;r&amp;quot;)&lt;br /&gt;
    file_out = open(&amp;quot;sortcuvout.txt&amp;quot;, &amp;quot;w&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
    try:&lt;br /&gt;
        # citim propozitia&lt;br /&gt;
        propozitie_main = file_in.readline().strip()&lt;br /&gt;
        # validam datele de intrare&lt;br /&gt;
        validare(propozitie_main)&lt;br /&gt;
        # sortam cuvintele in functie de ordinea alfabetica&lt;br /&gt;
        cuvinte_sortate = sort_words(propozitie_main.split())&lt;br /&gt;
        # scriem cuvintele sortate in fisierul de iesire&lt;br /&gt;
        for cuvant in cuvinte_sortate:&lt;br /&gt;
            file_out.write(cuvant + &amp;#039;\n&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
    # daca datele de intrare nu sunt valide, afisam un mesaj de eroare&lt;br /&gt;
    except ValueError:&lt;br /&gt;
        file_out.write(&amp;quot;Datele de intrare nu corespund restrictiilor impuse.&amp;quot;)&lt;br /&gt;
    # daca datele de intrare sunt incomplete, afisam un mesaj de eroare&lt;br /&gt;
    except IndexError:&lt;br /&gt;
        file_out.write(&amp;quot;Datele de intrare nu corespund restrictiilor impuse.&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>AntalKrisztian</name></author>
	</entry>
</feed>