<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=ReverseAndAdd%2F%EB%AC%B8%EB%B3%B4%EC%B0%BD</id>
	<title>ReverseAndAdd/문보창 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=ReverseAndAdd%2F%EB%AC%B8%EB%B3%B4%EC%B0%BD"/>
	<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=ReverseAndAdd/%EB%AC%B8%EB%B3%B4%EC%B0%BD&amp;action=history"/>
	<updated>2026-05-14T11:10:47Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.8</generator>
	<entry>
		<id>https://mediawiki.zeropage.org/index.php?title=ReverseAndAdd/%EB%AC%B8%EB%B3%B4%EC%B0%BD&amp;diff=38435&amp;oldid=prev</id>
		<title>imported&gt;Unknown at 05:27, 7 February 2021</title>
		<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=ReverseAndAdd/%EB%AC%B8%EB%B3%B4%EC%B0%BD&amp;diff=38435&amp;oldid=prev"/>
		<updated>2021-02-07T05:27:55Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==== 소감 ====&lt;br /&gt;
2005/02/19 Accepted 0:00.158 460&lt;br /&gt;
필요한 배열의 크기를 알고 있다면, 동적할당보다는 오히려 정적할당이 유리하다. 다음번엔 정적할당을 한 후 수행시간과 메모리를 비교해보자.&lt;br /&gt;
==== 코드(C++) ====&lt;br /&gt;
 // no10018 - Reverse and Add&lt;br /&gt;
 #include &amp;amp;lt;iostream&amp;amp;gt; &lt;br /&gt;
 #include &amp;amp;lt;cmath&amp;amp;gt; &lt;br /&gt;
 using namespace std; &lt;br /&gt;
 &lt;br /&gt;
 int makePalim(unsigned int * pal, unsigned int originN, int count); &lt;br /&gt;
 void showPalim(const unsigned int * pal, const int * nadd, const int n); &lt;br /&gt;
 &lt;br /&gt;
 int main() &lt;br /&gt;
 { &lt;br /&gt;
 	int n;                          // test의 수 &lt;br /&gt;
 	 int i; &lt;br /&gt;
 	unsigned int num;               // test &lt;br /&gt;
 	cin &amp;amp;gt;&amp;amp;gt; n; &lt;br /&gt;
 &lt;br /&gt;
 	unsigned int * palim = new unsigned int[n];             // palindrome &lt;br /&gt;
 	int * nAdd = new int[n];                                // add의 수 &lt;br /&gt;
 	 for (i=0; i&amp;amp;lt;n; i++) &lt;br /&gt;
 	{ &lt;br /&gt;
 		cin &amp;amp;gt;&amp;amp;gt; num;         &lt;br /&gt;
 		nAdd[i] = makePalim(palim, num, i); &lt;br /&gt;
 	} &lt;br /&gt;
 	showPalim(palim, nAdd, i); &lt;br /&gt;
 	delete [] nAdd; &lt;br /&gt;
 	delete [] palim; &lt;br /&gt;
 	return 0; &lt;br /&gt;
 } &lt;br /&gt;
 &lt;br /&gt;
 int makePalim(unsigned int * pal, unsigned int originN, int count) &lt;br /&gt;
 { &lt;br /&gt;
 	int nadd = 0;                   // add의 수 &lt;br /&gt;
 	 unsigned int reverseN;          // reverse한 수 &lt;br /&gt;
  	 int len, i;                     // 자리수 &lt;br /&gt;
 	 unsigned int temp, t; &lt;br /&gt;
 	while(true) &lt;br /&gt;
 	{ &lt;br /&gt;
 		reverseN = 0; &lt;br /&gt;
 		len = 1; &lt;br /&gt;
 		temp = originN;  &lt;br /&gt;
 		while (temp / 10 != 0) &lt;br /&gt;
 		{ &lt;br /&gt;
 			len++; &lt;br /&gt;
 			temp /= 10; &lt;br /&gt;
 		} &lt;br /&gt;
 		temp = originN; &lt;br /&gt;
 		for (i=0; i&amp;amp;lt;len; i++) &lt;br /&gt;
 		{ &lt;br /&gt;
 			t = temp / pow(10, len-1-i); &lt;br /&gt;
 			reverseN += t * pow(10, i); &lt;br /&gt;
 			temp -= t * pow(10, len-1-i); &lt;br /&gt;
 		} &lt;br /&gt;
 		if (originN == reverseN) &lt;br /&gt;
 			break; &lt;br /&gt;
 		originN = originN + reverseN; &lt;br /&gt;
 		nadd++; &lt;br /&gt;
 	} &lt;br /&gt;
 	pal[count] = originN; &lt;br /&gt;
 	return nadd; &lt;br /&gt;
 } &lt;br /&gt;
 &lt;br /&gt;
 void showPalim(const unsigned int * pal, const int * nadd, const int n) &lt;br /&gt;
 { &lt;br /&gt;
 	int i; &lt;br /&gt;
 	for (i=0; i&amp;amp;lt;n; i++) &lt;br /&gt;
 		cout &amp;amp;lt;&amp;amp;lt; nadd[i] &amp;amp;lt;&amp;amp;lt; &amp;quot; &amp;quot; &amp;amp;lt;&amp;amp;lt; pal[i] &amp;amp;lt;&amp;amp;lt; endl; &lt;br /&gt;
 }&lt;br /&gt;
=== 코드(Python) ===&lt;br /&gt;
 def ReverseAndAdd(n, count):&lt;br /&gt;
     if int(n) == int(n[::-1]):&lt;br /&gt;
         print count, n&lt;br /&gt;
         return&lt;br /&gt;
     else:&lt;br /&gt;
         count += 1&lt;br /&gt;
         ReverseAndAdd(str(int(n) + int(n[::-1])), count)&lt;br /&gt;
     &lt;br /&gt;
 if __name__== &amp;#039;__main__&amp;#039;:&lt;br /&gt;
     for numCase in range(0, input(), 1):&lt;br /&gt;
         n = raw_input()&lt;br /&gt;
         ReverseAndAdd(n, 0)&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
[[ReverseAndAdd]] [[문보창]]&lt;br /&gt;
&lt;/div&gt;</summary>
		<author><name>imported&gt;Unknown</name></author>
	</entry>
</feed>