A<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B_Tutorial%2FFunction%2Ffunction_recursion</id>
		<title>C++ Tutorial/Function/function recursion - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B_Tutorial%2FFunction%2Ffunction_recursion"/>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/Function/function_recursion&amp;action=history"/>
		<updated>2026-04-17T19:36:29Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/Function/function_recursion&amp;diff=2453&amp;oldid=prev</id>
		<title> в 14:21, 25 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/Function/function_recursion&amp;diff=2453&amp;oldid=prev"/>
				<updated>2010-05-25T14:21:17Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 14:21, 25 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/Function/function_recursion&amp;diff=2454&amp;oldid=prev</id>
		<title>Admin: 1 версия:&amp;#32;Импорт контента...</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/Function/function_recursion&amp;diff=2454&amp;oldid=prev"/>
				<updated>2010-05-25T10:29:44Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия: Импорт контента...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Demonstrate recursion==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt; &lt;br /&gt;
using namespace std; &lt;br /&gt;
 &lt;br /&gt;
int f(int n); &lt;br /&gt;
 &lt;br /&gt;
int main() &lt;br /&gt;
{ &lt;br /&gt;
  // use recursive version &lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;4 factorial is &amp;quot; &amp;lt;&amp;lt; f(4); &lt;br /&gt;
 &lt;br /&gt;
  return 0; &lt;br /&gt;
} &lt;br /&gt;
 &lt;br /&gt;
int f(int n)  &lt;br /&gt;
{ &lt;br /&gt;
  int answer; &lt;br /&gt;
 &lt;br /&gt;
  if(n==1)  &lt;br /&gt;
      return(1); &lt;br /&gt;
  &lt;br /&gt;
  answer = f(n-1)*n; &lt;br /&gt;
  return(answer); &lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;4 factorial is 24&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Print a string backwards using recursion==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt; &lt;br /&gt;
using namespace std; &lt;br /&gt;
 &lt;br /&gt;
void f(char *s); &lt;br /&gt;
 &lt;br /&gt;
int main() &lt;br /&gt;
{ &lt;br /&gt;
  char str[] = &amp;quot;this is a test&amp;quot;; &lt;br /&gt;
 &lt;br /&gt;
  f(str); &lt;br /&gt;
 &lt;br /&gt;
  return 0; &lt;br /&gt;
} &lt;br /&gt;
 &lt;br /&gt;
void f(char *s) &lt;br /&gt;
{ &lt;br /&gt;
  if(*s)  &lt;br /&gt;
    f(s+1);  &lt;br /&gt;
  else &lt;br /&gt;
    return; &lt;br /&gt;
 &lt;br /&gt;
  cout &amp;lt;&amp;lt; *s; &lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;tset a si siht&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Recursive factorial function==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using std::cout;&lt;br /&gt;
using std::endl;&lt;br /&gt;
#include &amp;lt;iomanip&amp;gt;&lt;br /&gt;
using std::setw;&lt;br /&gt;
unsigned long factorial( unsigned long ); // function prototype&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
   for ( int counter = 0; counter &amp;lt;= 50; counter++ )&lt;br /&gt;
      cout &amp;lt;&amp;lt; setw( 2 ) &amp;lt;&amp;lt; counter &amp;lt;&amp;lt; &amp;quot;! = &amp;quot; &amp;lt;&amp;lt; factorial( counter ) &amp;lt;&amp;lt; endl;&lt;br /&gt;
   return 0;&lt;br /&gt;
}&lt;br /&gt;
unsigned long factorial( unsigned long number )&lt;br /&gt;
{&lt;br /&gt;
   if ( number &amp;lt;= 1 )&lt;br /&gt;
      return 1;&lt;br /&gt;
   else&lt;br /&gt;
      return number * factorial( number - 1 );&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;0! = 1&lt;br /&gt;
 1! = 1&lt;br /&gt;
 2! = 2&lt;br /&gt;
 3! = 6&lt;br /&gt;
 4! = 24&lt;br /&gt;
 5! = 120&lt;br /&gt;
 6! = 720&lt;br /&gt;
 7! = 5040&lt;br /&gt;
 8! = 40320&lt;br /&gt;
 9! = 362880&lt;br /&gt;
10! = 3628800&lt;br /&gt;
11! = 39916800&lt;br /&gt;
12! = 479001600&lt;br /&gt;
13! = 1932053504&lt;br /&gt;
14! = 1278945280&lt;br /&gt;
15! = 2004310016&lt;br /&gt;
16! = 2004189184&lt;br /&gt;
17! = 4006445056&lt;br /&gt;
18! = 3396534272&lt;br /&gt;
19! = 109641728&lt;br /&gt;
20! = 2192834560&lt;br /&gt;
21! = 3099852800&lt;br /&gt;
22! = 3772252160&lt;br /&gt;
23! = 862453760&lt;br /&gt;
24! = 3519021056&lt;br /&gt;
25! = 2076180480&lt;br /&gt;
26! = 2441084928&lt;br /&gt;
27! = 1484783616&lt;br /&gt;
28! = 2919235584&lt;br /&gt;
29! = 3053453312&lt;br /&gt;
30! = 1409286144&lt;br /&gt;
31! = 738197504&lt;br /&gt;
32! = 2147483648&lt;br /&gt;
33! = 2147483648&lt;br /&gt;
34! = 0&lt;br /&gt;
35! = 0&lt;br /&gt;
36! = 0&lt;br /&gt;
37! = 0&lt;br /&gt;
38! = 0&lt;br /&gt;
39! = 0&lt;br /&gt;
40! = 0&lt;br /&gt;
41! = 0&lt;br /&gt;
42! = 0&lt;br /&gt;
43! = 0&lt;br /&gt;
44! = 0&lt;br /&gt;
45! = 0&lt;br /&gt;
46! = 0&lt;br /&gt;
47! = 0&lt;br /&gt;
48! = 0&lt;br /&gt;
49! = 0&lt;br /&gt;
50! = 0&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==The iterative factorial method.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using std::cout;&lt;br /&gt;
using std::endl;&lt;br /&gt;
#include &amp;lt;iomanip&amp;gt;&lt;br /&gt;
using std::setw;&lt;br /&gt;
unsigned long factorial( unsigned long );&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
   for ( int counter = 0; counter &amp;lt;= 20; counter++ )&lt;br /&gt;
      cout &amp;lt;&amp;lt; setw( 2 ) &amp;lt;&amp;lt; counter &amp;lt;&amp;lt; &amp;quot;! = &amp;quot; &amp;lt;&amp;lt; factorial( counter ) &amp;lt;&amp;lt; endl;&lt;br /&gt;
   return 0;&lt;br /&gt;
}&lt;br /&gt;
unsigned long factorial( unsigned long number )&lt;br /&gt;
{&lt;br /&gt;
   unsigned long result = 1;&lt;br /&gt;
   for ( unsigned long i = number; i &amp;gt;= 1; i-- )&lt;br /&gt;
      result *= i;&lt;br /&gt;
   return result;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;0! = 1&lt;br /&gt;
 1! = 1&lt;br /&gt;
 2! = 2&lt;br /&gt;
 3! = 6&lt;br /&gt;
 4! = 24&lt;br /&gt;
 5! = 120&lt;br /&gt;
 6! = 720&lt;br /&gt;
 7! = 5040&lt;br /&gt;
 8! = 40320&lt;br /&gt;
 9! = 362880&lt;br /&gt;
10! = 3628800&lt;br /&gt;
11! = 39916800&lt;br /&gt;
12! = 479001600&lt;br /&gt;
13! = 1932053504&lt;br /&gt;
14! = 1278945280&lt;br /&gt;
15! = 2004310016&lt;br /&gt;
16! = 2004189184&lt;br /&gt;
17! = 4006445056&lt;br /&gt;
18! = 3396534272&lt;br /&gt;
19! = 109641728&lt;br /&gt;
20! = 2192834560&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==The recursive fibonacci function.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using std::cout;&lt;br /&gt;
using std::cin;&lt;br /&gt;
using std::endl;&lt;br /&gt;
unsigned long fibonacci( unsigned long );&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
   cout &amp;lt;&amp;lt; &amp;quot;fibonacci( 20 ) = &amp;quot; &amp;lt;&amp;lt; fibonacci( 20 ) &amp;lt;&amp;lt; endl;&lt;br /&gt;
   cout &amp;lt;&amp;lt; &amp;quot;fibonacci( 30 ) = &amp;quot; &amp;lt;&amp;lt; fibonacci( 30 ) &amp;lt;&amp;lt; endl;&lt;br /&gt;
   cout &amp;lt;&amp;lt; &amp;quot;fibonacci( 35 ) = &amp;quot; &amp;lt;&amp;lt; fibonacci( 35 ) &amp;lt;&amp;lt; endl;&lt;br /&gt;
   return 0;&lt;br /&gt;
} &lt;br /&gt;
unsigned long fibonacci( unsigned long number )&lt;br /&gt;
{&lt;br /&gt;
   if ( ( number == 0 ) || ( number == 1 ) )&lt;br /&gt;
      return number;&lt;br /&gt;
   else &lt;br /&gt;
      return fibonacci( number - 1 ) + fibonacci( number - 2 );&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;fibonacci( 20 ) = 6765&lt;br /&gt;
fibonacci( 30 ) = 832040&lt;br /&gt;
fibonacci( 35 ) = 9227465&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>