Table of Contents

    SEMESTER – II Unit – 1: Section 6: Data Structure: Recursion

    Data Structure: Recursion (Definition, Advantages and Limitations)

    Recursion হলো এমন একটি পদ্ধতি যেখানে একটি function নিজেকেই বারবার call করে একটি সমস্যার সমাধান করে। এটি programming-এর একটি গুরুত্বপূর্ণ ধারণা।


    ১. Recursion কী?

    Recursion হলো এমন একটি process যেখানে একটি function নিজেকেই call করে যতক্ষণ না একটি নির্দিষ্ট condition পূরণ হয়।

    সহজভাবে:

    Function নিজেকে call করে → Problem ছোট হয় → শেষ পর্যন্ত solution পাওয়া যায়


    ২. Base Case এবং Recursive Case

    Recursion-এর দুইটি গুরুত্বপূর্ণ অংশ:

    • Base Case → যেখানে recursion বন্ধ হয়
    • Recursive Case → যেখানে function নিজেকে call করে

    ৩. Example: Factorial Program

    
    #include <stdio.h>
    
    int factorial(int n) {
        if(n == 0) {
            return 1;   // Base case
        } else {
            return n * factorial(n - 1);  // Recursive call
        }
    }
    
    int main() {
        int result = factorial(5);
        printf("Factorial = %d", result);
        return 0;
    }
    

    ৪. Recursion কীভাবে কাজ করে?

    Example: factorial(3)

    
    factorial(3)
    = 3 * factorial(2)
    = 3 * 2 * factorial(1)
    = 3 * 2 * 1 * factorial(0)
    = 3 * 2 * 1 * 1
    = 6
    

    এখানে function বারবার নিজেকে call করে এবং শেষে base case-এ এসে থামে।


    ৫. Recursion-এর সুবিধা (Advantages)

    • ✔ Code সহজ এবং ছোট হয়
    • ✔ Complex problem সহজে solve করা যায়
    • ✔ Divide and conquer technique-এ ব্যবহার হয়
    • ✔ Tree, graph, sorting algorithm-এ ব্যবহার হয়

    ৬. Recursion-এর সীমাবদ্ধতা (Limitations)

    • ❌ বেশি memory ব্যবহার করে (stack memory)
    • ❌ slow হতে পারে
    • ❌ base case না দিলে infinite loop হবে
    • ❌ debugging কঠিন

    ৭. Recursion vs Loop

    বিষয় Recursion Loop
    Structure Function call Iteration
    Memory বেশি লাগে কম লাগে
    Code ছোট ও সহজ বড় হতে পারে

    ৮. বাস্তব জীবনের উদাহরণ

    • Mirror reflection (আয়নায় আয়না)
    • Russian dolls (একটার ভিতরে আরেকটা)

    উপসংহার

    Recursion একটি powerful technique যা complex problem সহজভাবে সমাধান করতে সাহায্য করে। তবে এটি ব্যবহারের সময় base case নিশ্চিত করা এবং memory usage মাথায় রাখা জরুরি।


    Quick Revision

    • Recursion → function নিজেকে call করে
    • Base case → stopping condition
    • Recursive case → repeat call
    • Advantage → code সহজ
    • Limitation → memory বেশি লাগে
    Practice Quiz 17 MCQs Smart Learning

    Master This Topic with Smart Practice

    Reinforce what you just learned by solving high-quality MCQs. Improve accuracy, boost confidence, and prepare like a topper.

    Topic-wise MCQs
    Instant Results
    Improve Accuracy
    Exam Ready Practice
    Login & Start Quiz Create Free Account
    Save progress • Track results • Learn faster