<?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=0093_-_Numar_Maxim_Cuvinte</id>
	<title>0093 - Numar Maxim 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=0093_-_Numar_Maxim_Cuvinte"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0093_-_Numar_Maxim_Cuvinte&amp;action=history"/>
	<updated>2026-05-01T04:04:06Z</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=0093_-_Numar_Maxim_Cuvinte&amp;diff=8114&amp;oldid=prev</id>
		<title>AntalKrisztian: Pagină nouă: == Cerinţa == Să se scrie un program care citește mai multe propoziții și determină propoziția cu cele mai multe cuvinte. == Date de intrare == Fișierul de intrare &#039;&#039;&#039;cuvmaxin.txt&#039;&#039;&#039; conține pe prima linie un număr natural &#039;&#039;&#039;n&#039;&#039;&#039;, iar pe următoarele &#039;&#039;&#039;n&#039;&#039;&#039; linii câte 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;cuvmaxout.txt&#039;&#039;&#039; va conține pe prima linie propoziția cu cele mai multe...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0093_-_Numar_Maxim_Cuvinte&amp;diff=8114&amp;oldid=prev"/>
		<updated>2023-12-14T14:21:33Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Cerinţa == Să se scrie un program care citește mai multe propoziții și determină propoziția cu cele mai multe cuvinte. == Date de intrare == Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;cuvmaxin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie un număr natural &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039;, iar pe următoarele &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii câte 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;cuvmaxout.txt&amp;#039;&amp;#039;&amp;#039; va conține pe prima linie propoziția cu cele mai multe...&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 mai multe propoziții și determină propoziția cu cele mai multe cuvinte.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;cuvmaxin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie un număr natural &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039;, iar pe următoarele &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii câte 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;cuvmaxout.txt&amp;#039;&amp;#039;&amp;#039; va conține pe prima linie propoziția cu cele mai multe cuvinte.&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;0&amp;lt;n&amp;lt;100&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* fiecare propoziție va conține cel mult &amp;#039;&amp;#039;&amp;#039;255&amp;#039;&amp;#039;&amp;#039; de caractere&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; cuvmaxin.txt&lt;br /&gt;
 4&lt;br /&gt;
 somnoroase pasarele&lt;br /&gt;
 pe la cuiburi se aduna&lt;br /&gt;
 se ascund in ramurele&lt;br /&gt;
 noapte buna noapte buna&lt;br /&gt;
; cuvmaxout.txt&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse.&lt;br /&gt;
 pe la cuiburi se aduna&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; cuvmaxin.txt&lt;br /&gt;
 205ALA&lt;br /&gt;
; cuvmaxout.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(n_validare, propozitii_validare):&lt;br /&gt;
    # verificam daca n este in intervalul 0-100&lt;br /&gt;
    if n_validare &amp;lt;= 0 or n_validare &amp;gt; 100:&lt;br /&gt;
        raise ValueError  # ridicam o eroare daca n nu este in intervalul 0-100&lt;br /&gt;
    for propozitie in propozitii_validare:    # parcurgem lista de propozitii&lt;br /&gt;
        # verificam daca lungimea propozitiei este mai mica sau egala cu 255&lt;br /&gt;
        if len(propozitie) &amp;gt; 255:&lt;br /&gt;
            raise ValueError&lt;br /&gt;
        for caracter in propozitie:    # parcurgem fiecare caracter din propozitie&lt;br /&gt;
            # verificam daca caracterul este o litera mica a alfabetului englezesc sau un spatiu&lt;br /&gt;
            if not caracter.islower() and not caracter.isspace():&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 max_words_proposition determina propozitia cu cele mai multe cuvinte&lt;br /&gt;
def numar_max_cuvinte(propozitii):&lt;br /&gt;
    # determinam propozitia cu cele mai multe cuvinte&lt;br /&gt;
    propozitie_max_cuvinte = max(propozitii, key=lambda propozitie: len(propozitie.split()))&lt;br /&gt;
    return propozitie_max_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;cuvmaxin.txt&amp;quot;, &amp;quot;r&amp;quot;)&lt;br /&gt;
    file_out = open(&amp;quot;cuvmaxout.txt&amp;quot;, &amp;quot;w&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
    try:&lt;br /&gt;
        # citim numarul de propozitii&lt;br /&gt;
        n_main = int(file_in.readline())&lt;br /&gt;
        # citim propozitiile&lt;br /&gt;
        propozitii_main = [linie.strip() for linie in file_in]&lt;br /&gt;
        # validam datele de intrare&lt;br /&gt;
        validare(n_main, propozitii_main)&lt;br /&gt;
        # determinam propozitia cu cele mai multe cuvinte&lt;br /&gt;
        propozitie_max = numar_max_cuvinte(propozitii_main)&lt;br /&gt;
        # scriem propozitia cu cele mai multe cuvinte in fisierul de iesire&lt;br /&gt;
        file_out.write(propozitie_max + &amp;#039;\n&amp;#039;)&lt;br /&gt;
&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;
    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>