<?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=1647_-_Cumpanit</id>
	<title>1647 - Cumpanit - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=1647_-_Cumpanit"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1647_-_Cumpanit&amp;action=history"/>
	<updated>2026-05-02T00:53:11Z</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=1647_-_Cumpanit&amp;diff=8319&amp;oldid=prev</id>
		<title>Ramona Dragoș: Pagină nouă: == Enunt == Un număr natural nenul n se numește cumpănit dacă în descompunerea sa în factori primi suma bazelor este egală cu suma exponenților. De exemplu, numerele 72 = 2^3 * 3^2 , 5760 = 2^7 * 3^2 * 5^1 sunt cumpănite.  == Cerința == Să se scrie un program care citește două numere naturale nenule a și b și determină toate numerele cumpănite din intervalul închis [a, b]. De exemplu, dacă a=2 și b=99, numerele cumpănite cuprinse între 2 şi 99 sunt 4, 2...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1647_-_Cumpanit&amp;diff=8319&amp;oldid=prev"/>
		<updated>2023-12-22T20:06:28Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunt == Un număr natural nenul n se numește cumpănit dacă în descompunerea sa în factori primi suma bazelor este egală cu suma exponenților. De exemplu, numerele 72 = 2^3 * 3^2 , 5760 = 2^7 * 3^2 * 5^1 sunt cumpănite.  == Cerința == Să se scrie un program care citește două numere naturale nenule a și b și determină toate numerele cumpănite din intervalul închis [a, b]. De exemplu, dacă a=2 și b=99, numerele cumpănite cuprinse între 2 şi 99 sunt 4, 2...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunt ==&lt;br /&gt;
Un număr natural nenul n se numește cumpănit dacă în descompunerea sa în factori primi suma bazelor este egală cu suma exponenților. De exemplu, numerele 72 = 2^3 * 3^2 , 5760 = 2^7 * 3^2 * 5^1 sunt cumpănite.&lt;br /&gt;
&lt;br /&gt;
== Cerința ==&lt;br /&gt;
Să se scrie un program care citește două numere naturale nenule a și b și determină toate numerele cumpănite din intervalul închis [a, b].&lt;br /&gt;
De exemplu, dacă a=2 și b=99, numerele cumpănite cuprinse între 2 şi 99 sunt 4, 27, 48 şi 72.&lt;br /&gt;
&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fişierul de intrare cumpanitin.txt conţine pe prima linie numerele naturale nenule a și b despărțite prin exact un spațiu, cu semnificaţia de mai sus.&lt;br /&gt;
&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fişierul de ieşire cumpanitout.txt va conţine numerele căutate, scrise în ordine crescătoare, câte unul pe fiecare linie.&lt;br /&gt;
&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
*2 &amp;amp;les; a &amp;amp;les; b &amp;amp;les; 10^14.&lt;br /&gt;
*Pentru 25% din teste se garantează că 2 ≤ a ≤ b ≤ 106.&lt;br /&gt;
== Exemplu 1 ==&lt;br /&gt;
;cumpanitin.txt&lt;br /&gt;
:2 99&lt;br /&gt;
;cumpanitout.txt&lt;br /&gt;
:Datele corespund &lt;br /&gt;
:4&lt;br /&gt;
:27&lt;br /&gt;
:48&lt;br /&gt;
:72&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplu 2 ==&lt;br /&gt;
;cumpanitin.txt&lt;br /&gt;
:1 0 -1&lt;br /&gt;
;cumpanitout.txt&lt;br /&gt;
:Datele nu corespund&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;
#1647 - Cumpanit&lt;br /&gt;
def este_cumpanit(numar):&lt;br /&gt;
    # Calculează descompunerea în factori primi și verifică condiția cumpănită&lt;br /&gt;
    divizor = 2&lt;br /&gt;
    suma_baze = 0&lt;br /&gt;
    suma_exponenti = 0&lt;br /&gt;
&lt;br /&gt;
    while numar &amp;gt; 1:&lt;br /&gt;
        putere = 0&lt;br /&gt;
        while numar % divizor == 0:&lt;br /&gt;
            numar //= divizor&lt;br /&gt;
            putere += 1&lt;br /&gt;
        if putere &amp;gt; 0:&lt;br /&gt;
            suma_baze += divizor&lt;br /&gt;
            suma_exponenti += putere&lt;br /&gt;
        divizor += 1&lt;br /&gt;
&lt;br /&gt;
    return suma_baze == suma_exponenti&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    try:&lt;br /&gt;
        with open(&amp;quot;cumpanitin.txt&amp;quot;, &amp;quot;r&amp;quot;) as fin:&lt;br /&gt;
            a, b = map(int, fin.readline().strip().split())&lt;br /&gt;
    except FileNotFoundError:&lt;br /&gt;
        print(&amp;quot;Fișierul cumpanitin.txt nu a fost găsit.&amp;quot;)&lt;br /&gt;
        return&lt;br /&gt;
    except ValueError:&lt;br /&gt;
        print(&amp;quot;Datele din fișierul de intrare nu sunt corecte.&amp;quot;)&lt;br /&gt;
        return&lt;br /&gt;
&lt;br /&gt;
    if not (2 &amp;lt;= a &amp;lt;= b &amp;lt;= 10 ** 14):&lt;br /&gt;
        print(&amp;quot;Datele nu corespund restricțiilor.&amp;quot;)&lt;br /&gt;
        return&lt;br /&gt;
&lt;br /&gt;
    try:&lt;br /&gt;
        with open(&amp;quot;cumpanitout.txt&amp;quot;, &amp;quot;w&amp;quot;) as fout:&lt;br /&gt;
            for numar in range(a, b + 1):&lt;br /&gt;
                if este_cumpanit(numar):&lt;br /&gt;
                    fout.write(str(numar) + &amp;quot;\n&amp;quot;)&lt;br /&gt;
        print(&amp;quot;Datele corespund.&amp;quot;)&lt;br /&gt;
    except IOError:&lt;br /&gt;
        print(&amp;quot;Nu s-a putut scrie în fișierul de ieșire.&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main()&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Ramona Dragoș</name></author>
	</entry>
</feed>