<?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=2463_-_Inequation</id>
	<title>2463 - Inequation - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=2463_-_Inequation"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2463_-_Inequation&amp;action=history"/>
	<updated>2026-05-01T05:41:08Z</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=2463_-_Inequation&amp;diff=8736&amp;oldid=prev</id>
		<title>Vasiliu Costel Andrei: Pagină nouă: == Cerința == Această problemă nu are o descriere plicticoasă, menită să vă încurce.Trebuie doar să aflați cel mai mare număr natural n, astfel încât b^0+b^1+...+b^n≤y, unde b și y sunt valori cunoscute.  == Date de intrare == Fișierul de intrare inequationin.txt va conține pe prima linie numărul t, reprezentând numărul de teste ale problemei.Apoi urmează 3*t rânduri, pentru fiecare test fiind precizată baza b, numărul de cifre ale lui y, precum și c...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2463_-_Inequation&amp;diff=8736&amp;oldid=prev"/>
		<updated>2023-12-31T18:24:52Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Cerința == Această problemă nu are o descriere plicticoasă, menită să vă încurce.Trebuie doar să aflați cel mai mare număr natural n, astfel încât b^0+b^1+...+b^n≤y, unde b și y sunt valori cunoscute.  == Date de intrare == Fișierul de intrare inequationin.txt va conține pe prima linie numărul t, reprezentând numărul de teste ale problemei.Apoi urmează 3*t rânduri, pentru fiecare test fiind precizată baza b, numărul de cifre ale lui y, precum și c...&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;
Această problemă nu are o descriere plicticoasă, menită să vă încurce.Trebuie doar să aflați cel mai mare număr natural n, astfel încât b^0+b^1+...+b^n≤y, unde b și y sunt valori cunoscute.&lt;br /&gt;
&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare inequationin.txt va conține pe prima linie numărul t, reprezentând numărul de teste ale problemei.Apoi urmează 3*t rânduri, pentru fiecare test fiind precizată baza b, numărul de cifre ale lui y, precum și cifrele numărului y, aflate fiecare pe un rând separat.&lt;br /&gt;
&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul de ieșire inequationout.txt va conține pe linia i numărul maxim de termeni pentru care se respectă condiția pentru testul cu numărul de ordine t.&lt;br /&gt;
&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
* 1 &amp;amp;les; &amp;#039;&amp;#039;&amp;#039;b&amp;#039;&amp;#039;&amp;#039; &amp;amp;les; 100&lt;br /&gt;
* numărul de cifre ale lui &amp;#039;&amp;#039;&amp;#039;y&amp;#039;&amp;#039;&amp;#039; &amp;amp;les; 25.000&lt;br /&gt;
&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; inequationin.txt&lt;br /&gt;
: 1&lt;br /&gt;
: 2&lt;br /&gt;
: 2&lt;br /&gt;
: 16&lt;br /&gt;
; Ieșire&lt;br /&gt;
: Datele de intrare corespund restricțiilor impuse&lt;br /&gt;
; inequationout.txt&lt;br /&gt;
: 4&lt;br /&gt;
&lt;br /&gt;
=== Explicație ===&lt;br /&gt;
2^0+2^1+2^2+2^3=15≤16, deci în total patru termeni.&lt;br /&gt;
&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; inequationin.txt&lt;br /&gt;
: 1&lt;br /&gt;
: 101&lt;br /&gt;
: 2&lt;br /&gt;
: 16&lt;br /&gt;
; Ieșire&lt;br /&gt;
: Datele de intrare NU corespund restricțiilor impuse&lt;br /&gt;
&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
#2463 - Inequation&lt;br /&gt;
&lt;br /&gt;
def validare_date(b, y):&lt;br /&gt;
    if not (1 &amp;lt;= b &amp;lt;= 100):&lt;br /&gt;
        return False&lt;br /&gt;
    if not (1 &amp;lt;= len(y) &amp;lt;= 25000):&lt;br /&gt;
        return False&lt;br /&gt;
    if not all(0 &amp;lt;= int(cifra) &amp;lt;= 9 for cifra in y):&lt;br /&gt;
        return False&lt;br /&gt;
    return True&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def calculeaza_numar_maxim_termeni(b, y):&lt;br /&gt;
    suma = 0&lt;br /&gt;
    numar_termeni = 0&lt;br /&gt;
    i = 0&lt;br /&gt;
    while suma + b ** i &amp;lt;= int(y):&lt;br /&gt;
        suma += b ** i&lt;br /&gt;
        numar_termeni += 1&lt;br /&gt;
        i += 1&lt;br /&gt;
    return numar_termeni&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    with open(&amp;quot;inequationin.txt&amp;quot;, &amp;quot;r&amp;quot;) as file_input:&lt;br /&gt;
        t = int(file_input.readline().strip())&lt;br /&gt;
        for _ in range(t):&lt;br /&gt;
            b = int(file_input.readline().strip())&lt;br /&gt;
            lungime_y = int(file_input.readline().strip())&lt;br /&gt;
            y = file_input.readline().strip()&lt;br /&gt;
&lt;br /&gt;
            if validare_date(b, y):&lt;br /&gt;
                print(&amp;quot;Datele de intrare corespund restricțiilor impuse&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
                rezultat = calculeaza_numar_maxim_termeni(b, y)&lt;br /&gt;
&lt;br /&gt;
                with open(&amp;quot;inequationout.txt&amp;quot;, &amp;quot;w&amp;quot;) as file_output:&lt;br /&gt;
                    file_output.write(str(rezultat) + &amp;quot;\n&amp;quot;)&lt;br /&gt;
            else:&lt;br /&gt;
                print(&amp;quot;Datele de intrare NU corespund restricțiilor impuse&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>Vasiliu Costel Andrei</name></author>
	</entry>
</feed>