<?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=2230_-_paindrom3</id>
	<title>2230 - paindrom3 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=2230_-_paindrom3"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2230_-_paindrom3&amp;action=history"/>
	<updated>2026-05-01T19:02:48Z</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=2230_-_paindrom3&amp;diff=9046&amp;oldid=prev</id>
		<title>Miawinator: Pagină nouă: Gigel a învăţat la şcoală un nou cuvânt: palindrom. El ştie acum că un palindrom este o construcţie formată din litere sau/şi cifre care arată la fel citită de la început spre sfârşit sau citită de la sfârşit spre început. De exemplu numerele &lt;code&gt;2552&lt;/code&gt; și &lt;code&gt;12321&lt;/code&gt; au proprietatea de palindrom. Deoarece lui Gigel îi place să se joace cu cifrele, el îşi pune următoarea problemă: dat fiind un număr natural, pot fi rearanjate cifrele...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2230_-_paindrom3&amp;diff=9046&amp;oldid=prev"/>
		<updated>2024-01-04T23:38:39Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: Gigel a învăţat la şcoală un nou cuvânt: palindrom. El ştie acum că un palindrom este o construcţie formată din litere sau/şi cifre care arată la fel citită de la început spre sfârşit sau citită de la sfârşit spre început. De exemplu numerele &amp;lt;code&amp;gt;2552&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;12321&amp;lt;/code&amp;gt; au proprietatea de palindrom. Deoarece lui Gigel îi place să se joace cu cifrele, el îşi pune următoarea problemă: dat fiind un număr natural, pot fi rearanjate cifrele...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Gigel a învăţat la şcoală un nou cuvânt: palindrom. El ştie acum că un palindrom este o construcţie formată din litere sau/şi cifre care arată la fel citită de la început spre sfârşit sau citită de la sfârşit spre început. De exemplu numerele &amp;lt;code&amp;gt;2552&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;12321&amp;lt;/code&amp;gt; au proprietatea de palindrom. Deoarece lui Gigel îi place să se joace cu cifrele, el îşi pune următoarea problemă: dat fiind un număr natural, pot fi rearanjate cifrele lui astfel încât să obţinem un palindrom? Dacă da, care este numărul maxim palindrom care poate fi obţinut?&lt;br /&gt;
&lt;br /&gt;
= Cerința =&lt;br /&gt;
Fiind dat un număr natural &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; să se determine cel mai mare număr palindrom care se poate obţine cu cifrele numărului &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
= Date de intrare =&lt;br /&gt;
Fișierul de intrare &amp;lt;code&amp;gt;input.txt&amp;lt;/code&amp;gt; conţine pe prima linie numărul natural &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
= Date de ieșire =&lt;br /&gt;
Fișierul de ieșire &amp;lt;code&amp;gt;output.txt&amp;lt;/code&amp;gt; conţine pe prima linie cel mai mare număr palindrom care se poate obţine cu cifrele numărului &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
= Restricții și precizări =&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;0 &amp;lt; n &amp;lt; 2 147 483 648&amp;lt;/code&amp;gt;&lt;br /&gt;
* Pentru datele de test există întotdeauna soluţie&lt;br /&gt;
&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
input.txt:&lt;br /&gt;
&lt;br /&gt;
3121321&lt;br /&gt;
&lt;br /&gt;
output.txt:&lt;br /&gt;
&lt;br /&gt;
3211123&lt;br /&gt;
&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
input.txt:&lt;br /&gt;
&lt;br /&gt;
999999999999999999999999999999&lt;br /&gt;
&lt;br /&gt;
Output:&lt;br /&gt;
&lt;br /&gt;
Input-ul nu convine conditiilor&lt;br /&gt;
&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python3&amp;quot; line=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
def verificare(n):&lt;br /&gt;
    if not(1&amp;lt;=n&amp;lt;=2147483648):&lt;br /&gt;
        print(&amp;quot;Input-ul nu convine conditiilor&amp;quot;)&lt;br /&gt;
        exit()&lt;br /&gt;
&lt;br /&gt;
with open(&amp;quot;input.txt&amp;quot;) as f:&lt;br /&gt;
    n = int(next(f))&lt;br /&gt;
    verificare(n)&lt;br /&gt;
&lt;br /&gt;
f = [0] * 10&lt;br /&gt;
while n:&lt;br /&gt;
    f[n % 10] += 1&lt;br /&gt;
    n //= 10&lt;br /&gt;
&lt;br /&gt;
k = -1&lt;br /&gt;
for i in range(10):&lt;br /&gt;
    if f[i] % 2:&lt;br /&gt;
        f[i] -= 1&lt;br /&gt;
        k = i&lt;br /&gt;
&lt;br /&gt;
with open(&amp;quot;output.txt&amp;quot;, &amp;quot;w&amp;quot;) as fout:&lt;br /&gt;
    for i in range(9, -1, -1):&lt;br /&gt;
        if f[i]:&lt;br /&gt;
            print(str(i) * (f[i] // 2), end=&amp;quot;&amp;quot;, file=fout)&lt;br /&gt;
    if k &amp;gt;= 0:&lt;br /&gt;
        print(k, end=&amp;quot;&amp;quot;, file=fout)&lt;br /&gt;
    for i in range(10):&lt;br /&gt;
        if f[i]:&lt;br /&gt;
            print(str(i) * (f[i] // 2), end=&amp;quot;&amp;quot;, file=fout)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Miawinator</name></author>
	</entry>
</feed>