রিকার্সিভ ফংশন (Recursive Function)

রিকার্সিভরিকার্সিভ ফাংশনঃ-

যে ফংশন নিজে নিজেকে কল করে সে ফাংশন কে রিকার্সিভ ফাংশন বলে। বিষয়টা একদম সহজ আমরা আস্তে এর গভীরে যাব। ধীরে কোড বুঝে পরতে হবে এবং কোড গুলো লিখে এক্সিকিউট করতে হবে।

সিনট্যাক্সঃ

recursive-function.js
function recursefn() {
    // function code
    recursefn();
    // function code
}

recursefn();

আসুন আমরা একটা কোড লিখি যেইটা আমাদের ফ্যাক্টোরিয়াল নাম্বার বের করে দিবে। যেখানে আমরা ইনপুট হিসেবে একটা নাম্বার দিব এবং আউটপুট হিসবে আমরা ঐ ইনপুটের ফ্যাক্টোরিয়াল পাব।

factorial.js

function factorial(x) {

    // যদি শূন্য হয় আমরা জানি সেক্ষেত্রে ফ্যাক্টোরিয়াল 1 হয় 
    if (x === 0) {
        return 1;
    }

    // যদি ধনাত্মক সংখ্যা হয় সেক্ষত্রে আমারা রিকার্সিভ ফাংশন কে কল করব এবং প্রতিবার ইনপুট সংখ্যা থেকে ১ বিয়োগ করে দিব। 
    else {
        return x * factorial(x - 1);
    }
}
// একটা সংখ্যা ইনপুট হিসবে নিলাম। 
const num = 3;

// যদি ইনপুট নাম্বার পজিটিভ বা ধনাত্মক হয় তাহলে আমি ফাংশন কল করব এবং যে আউটপুট পাবো সেইটা একটা ভেরিয়েবল এর মধ্যে রেখে দিব।
if (num > 0) {
    let result = factorial(num);
    console.log(` ইনপুট নাম্বার ${num} এর ফ্যাক্টোরিয়াল সংখ্যা {  result }`)
}

এখন একটু জেনে নেই এইটা আসলে কিভাবে এক্সকিউট হচ্ছে?

recursive function execution flow

কখন আপনি রিকার্সিভ ফাংশন ব্যাবহার করবেন ?

১। যখন আপনি কোন একটা ফাংশনকে ছোট ছোট সাব প্রব্লেমে ভাগ করতে চান। এইটাকে divide-and-conquer approach নামেও বলা হয়ে থাকে।

২। আপনি যখন কোন গ্রাফের ট্রাভার্স করতে চাইবেন।

৩। আপনি যখন কোন পর্যায়ক্রমিক ভ্যালু চাইবেন যেমনঃ- ফিবোনাক্কি

কখন আপনি রিকার্সিভ ফাংশন ব্যাবহার করবেন না ?

১। যখন আপনি মনে করবেন যে প্রভলেমটা লুপ দিয়ে করা সম্ভব

২। যদি প্রভলেমটা অনেক বেশি জটিল এবং বড় হয়ে যায় ।

৩। যদি আপনি মনে করেন আপনার কোডে পারফর্মেন্স এর সমস্যা হচ্ছে। কারণ তুলনা মূলক ভাবে রিকার্সিভ ফাংশন ধীরগতির।

Last updated