{"id":91,"date":"2026-05-20T09:27:36","date_gmt":"2026-05-20T09:27:36","guid":{"rendered":"https:\/\/gigz.pk\/php\/?post_type=lesson&#038;p=91"},"modified":"2026-05-21T14:39:05","modified_gmt":"2026-05-21T14:39:05","slug":"recursion-basics","status":"publish","type":"lesson","link":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics","title":{"rendered":"Recursion Basics"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">Introduction<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">Recursion is a programming technique where a function calls itself to solve a problem. It is commonly used in computer science to break large problems into smaller and simpler subproblems.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Recursion is widely used in algorithms, mathematics, searching, sorting, tree structures, and problem-solving applications.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Objectives<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">By the end of this training, you will be able to:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Understand the concept of recursion<\/li>\n\n\n\n<li>Identify base cases and recursive cases<\/li>\n\n\n\n<li>Write simple recursive functions<\/li>\n\n\n\n<li>Solve mathematical and logical problems using recursion<\/li>\n\n\n\n<li>Compare recursion with loops<\/li>\n\n\n\n<li>Understand advantages and limitations of recursion<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">What is Recursion<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">Recursion occurs when a function repeatedly calls itself until a specific condition is met.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">A recursive function usually contains:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Base Case<\/li>\n\n\n\n<li>Recursive Case<\/li>\n<\/ul>\n\n\n\n<p class=\"wp-block-paragraph\">The base case stops the function from calling itself endlessly, while the recursive case continues the process.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Structure of a Recursive Function<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">Basic structure:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>def function_name():<br>    if condition:<br>        return value<br>    else:<br>        return function_name()<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Understanding the Base Case<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">The base case is the stopping condition in recursion. Without a base case, the function would continue forever and cause an error.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Example:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>def countdown(n):<br>    if n == 0:<br>        print(\"Finished\")<br>    else:<br>        print(n)<br>        countdown(n - 1)<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">How Recursion Works<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">When a recursive function is called:<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>The function executes<\/li>\n\n\n\n<li>It calls itself with a smaller problem<\/li>\n\n\n\n<li>Each call waits for the next call to finish<\/li>\n\n\n\n<li>The process continues until the base case is reached<\/li>\n\n\n\n<li>The function calls return one by one<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\">Example of Recursion<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">Factorial Calculation<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Factorial of 5:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">5 \u00d7 4 \u00d7 3 \u00d7 2 \u00d7 1 = 120<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Recursive solution:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>def factorial(n):<br>    if n == 1:<br>        return 1<br>    else:<br>        return n * factorial(n - 1)<br><br>print(factorial(5))<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Output:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>120<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Recursive Countdown Example<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>def countdown(number):<br>    if number == 0:<br>        print(\"Done\")<br>    else:<br>        print(number)<br>        countdown(number - 1)<br><br>countdown(5)<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Recursive Sum Example<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>def recursive_sum(n):<br>    if n == 1:<br>        return 1<br>    return n + recursive_sum(n - 1)<br><br>print(recursive_sum(5))<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Output:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>15<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Recursion vs Loops<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">Recursion<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Function calls itself<\/li>\n\n\n\n<li>Easier for complex problems<\/li>\n\n\n\n<li>Uses more memory<\/li>\n\n\n\n<li>Cleaner code for some algorithms<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">Loops<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Repeats using iteration<\/li>\n\n\n\n<li>Faster for simple repetition<\/li>\n\n\n\n<li>Uses less memory<\/li>\n\n\n\n<li>Easier for beginners<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Advantages of Recursion<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Simplifies complex problems<\/li>\n\n\n\n<li>Produces cleaner and shorter code<\/li>\n\n\n\n<li>Useful for tree and graph structures<\/li>\n\n\n\n<li>Common in divide-and-conquer algorithms<\/li>\n\n\n\n<li>Helps solve mathematical problems naturally<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Disadvantages of Recursion<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Can use more memory<\/li>\n\n\n\n<li>Slower than loops in some cases<\/li>\n\n\n\n<li>Risk of infinite recursion<\/li>\n\n\n\n<li>Difficult to debug for beginners<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Common Applications of Recursion<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">Recursion is commonly used in:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Factorial calculations<\/li>\n\n\n\n<li>Fibonacci sequence<\/li>\n\n\n\n<li>Tree traversal<\/li>\n\n\n\n<li>Searching algorithms<\/li>\n\n\n\n<li>Sorting algorithms<\/li>\n\n\n\n<li>File directory navigation<\/li>\n\n\n\n<li>Mathematical computations<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Fibonacci Sequence Example<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code>def fibonacci(n):<br>    if n &lt;= 1:<br>        return n<br>    return fibonacci(n - 1) + fibonacci(n - 2)<br><br>print(fibonacci(6))<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Output:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>8<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Best Practices for Recursion<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Always define a clear base case<\/li>\n\n\n\n<li>Reduce the problem size in each call<\/li>\n\n\n\n<li>Avoid unnecessary recursive calls<\/li>\n\n\n\n<li>Test with small inputs first<\/li>\n\n\n\n<li>Use recursion only when it improves clarity<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Real World Uses of Recursion<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Website menu systems<\/li>\n\n\n\n<li>Folder and file navigation<\/li>\n\n\n\n<li>Artificial intelligence algorithms<\/li>\n\n\n\n<li>Game development<\/li>\n\n\n\n<li>Data structure processing<\/li>\n\n\n\n<li>Search engines<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Conclusion<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">Recursion is a powerful programming technique used to solve problems by breaking them into smaller tasks. Understanding recursion improves problem-solving skills and helps developers work with advanced algorithms and data structures efficiently.<\/p>\n\n\n<div class=\"yoast-breadcrumbs\"><span><span><a href=\"https:\/\/gigz.pk\/php\">Home<\/a><\/span> \u00bb <span class=\"breadcrumb_last\" aria-current=\"page\">Intermediate PHP > Functions > Recursion Basics<\/span><\/span><\/div>\n\n\n<div class=\"schema-faq wp-block-yoast-faq-block\"><div class=\"schema-faq-section\" id=\"faq-question-1779269214502\"><strong class=\"schema-faq-question\"><\/strong> <p class=\"schema-faq-answer\"><\/p> <\/div> <\/div>\n","protected":false},"menu_order":24,"template":"","class_list":["post-91","lesson","type-lesson","status-publish","hentry"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.8 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Recursion Basics - Learn PHP with GiGz.PK<\/title>\n<meta name=\"description\" content=\"Learn recursion basics with examples, recursive functions, factorials, Fibonacci sequence, and programming concepts.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/gigz.pk\/php\/?lesson=recursion-basics\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Recursion Basics - Learn PHP with GiGz.PK\" \/>\n<meta property=\"og:description\" content=\"Learn recursion basics with examples, recursive functions, factorials, Fibonacci sequence, and programming concepts.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/gigz.pk\/php\/?lesson=recursion-basics\" \/>\n<meta property=\"og:site_name\" content=\"Learn PHP with GiGz.PK\" \/>\n<meta property=\"article:modified_time\" content=\"2026-05-21T14:39:05+00:00\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data1\" content=\"2 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":[\"WebPage\",\"FAQPage\"],\"@id\":\"https:\\\/\\\/gigz.pk\\\/php\\\/?lesson=recursion-basics\",\"url\":\"https:\\\/\\\/gigz.pk\\\/php\\\/?lesson=recursion-basics\",\"name\":\"Recursion Basics - Learn PHP with GiGz.PK\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/gigz.pk\\\/php\\\/#website\"},\"datePublished\":\"2026-05-20T09:27:36+00:00\",\"dateModified\":\"2026-05-21T14:39:05+00:00\",\"description\":\"Learn recursion basics with examples, recursive functions, factorials, Fibonacci sequence, and programming concepts.\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/gigz.pk\\\/php\\\/?lesson=recursion-basics#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/gigz.pk\\\/php\\\/?lesson=recursion-basics\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/gigz.pk\\\/php\\\/?lesson=recursion-basics#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/gigz.pk\\\/php\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Intermediate PHP > Functions > Recursion Basics\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/gigz.pk\\\/php\\\/#website\",\"url\":\"https:\\\/\\\/gigz.pk\\\/php\\\/\",\"name\":\"Learn PHP with GiGz.PK\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/gigz.pk\\\/php\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Recursion Basics - Learn PHP with GiGz.PK","description":"Learn recursion basics with examples, recursive functions, factorials, Fibonacci sequence, and programming concepts.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics","og_locale":"en_US","og_type":"article","og_title":"Recursion Basics - Learn PHP with GiGz.PK","og_description":"Learn recursion basics with examples, recursive functions, factorials, Fibonacci sequence, and programming concepts.","og_url":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics","og_site_name":"Learn PHP with GiGz.PK","article_modified_time":"2026-05-21T14:39:05+00:00","twitter_card":"summary_large_image","twitter_misc":{"Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":["WebPage","FAQPage"],"@id":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics","url":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics","name":"Recursion Basics - Learn PHP with GiGz.PK","isPartOf":{"@id":"https:\/\/gigz.pk\/php\/#website"},"datePublished":"2026-05-20T09:27:36+00:00","dateModified":"2026-05-21T14:39:05+00:00","description":"Learn recursion basics with examples, recursive functions, factorials, Fibonacci sequence, and programming concepts.","breadcrumb":{"@id":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/gigz.pk\/php\/?lesson=recursion-basics"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/gigz.pk\/php\/?lesson=recursion-basics#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/gigz.pk\/php"},{"@type":"ListItem","position":2,"name":"Intermediate PHP > Functions > Recursion Basics"}]},{"@type":"WebSite","@id":"https:\/\/gigz.pk\/php\/#website","url":"https:\/\/gigz.pk\/php\/","name":"Learn PHP with GiGz.PK","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/gigz.pk\/php\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"}]}},"_links":{"self":[{"href":"https:\/\/gigz.pk\/php\/index.php?rest_route=\/wp\/v2\/lesson\/91","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/gigz.pk\/php\/index.php?rest_route=\/wp\/v2\/lesson"}],"about":[{"href":"https:\/\/gigz.pk\/php\/index.php?rest_route=\/wp\/v2\/types\/lesson"}],"wp:attachment":[{"href":"https:\/\/gigz.pk\/php\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=91"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}