<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Kawsar Bin Siraj</title>
    <description>The latest articles on DEV Community by Kawsar Bin Siraj (@kawsarbinsiraj).</description>
    <link>https://dev.to/kawsarbinsiraj</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F912631%2F65a7d091-5872-46a5-80fc-3839b869d0db.jpeg</url>
      <title>DEV Community: Kawsar Bin Siraj</title>
      <link>https://dev.to/kawsarbinsiraj</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/kawsarbinsiraj"/>
    <language>en</language>
    <item>
      <title>রিকার্সন নিয়ে কানাঘুষা</title>
      <dc:creator>Kawsar Bin Siraj</dc:creator>
      <pubDate>Mon, 28 Aug 2023 04:34:00 +0000</pubDate>
      <link>https://dev.to/kawsarbinsiraj/rikaarsn-niyye-kaanaaghussaa-1hk6</link>
      <guid>https://dev.to/kawsarbinsiraj/rikaarsn-niyye-kaanaaghussaa-1hk6</guid>
      <description>&lt;h2&gt;
  
  
  &lt;strong&gt;রিকার্সন (Recursion) কি?&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;রিকার্শন হলো একটি প্রোগ্রামিং ধারণা যেখানে একটি ফাংশন নিজেকে নিজেকে স্থানীয় ব্যবস্থার একটি অংশ হিসেবে ডাকে। অন্যভাবে বলতে, একটি রিকার্সিভ ফাংশন হলো একটি ফাংশন যা একটি সমস্য়া সমাধান করে এমনভাবে যে, সে নিজেকে একই সমস্য়ার আবদ্ধ রূপের ছোট ইনস্ট্যান্সগুলির সাথে কল করে। প্রতিটি রিকার্সিভ কলটি মূল সমস্য়ার একটি ছোট উপসেটে কাজ করে যা একটি বেস কেসে পৌঁছানোর জন্য থামে।&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--oSTymC3W--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/rluad62fv2fu9x2bh5cj.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--oSTymC3W--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/rluad62fv2fu9x2bh5cj.png" alt="Image description" width="724" height="249"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  রিকার্সিভ ফাংশনের মূল ঘটকগুলি হলো:
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;বেস কেস: এটি হলো শর্ত যা নির্ধারণ করে যখন রিকার্সন থামবে। এটি সমস্যার সবচেয়ে সাধারণ ইনস্ট্যান্স যা আবদ্ধ রূপে বিনা আরও রিকার্সন সমস্যা সমাধান করা যায়।&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;রিকার্সিভ কেস: এটি ফাংশনের অংশ যেখানে সে নিজেকে একটি পরিবর্তিত ইনপুট দিয়ে ডাকে, বেস কেসে নিকট চলে আসে। রিকার্সিভ কেসটি মূল সমস্যাটি আবদ্ধ রূপের ছোট সাবপ্রবলেমগুলির সাথে অধিকতর কাজ করে।&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;থামানোর শর্ত: এটি রিকার্সন শেষ হওয়ার বিন্দুও হতে পারে, এটি অত্যন্ত গুরুত্বপূর্ণ যে রিকার্সন অবিরত চলে না এবং অসীম রিকার্সনে পরিণত হয় না।&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;রিকার্সন স্বাভাবিকভাবে সমস্যা সমাধান করতে একটি শক্তিশালী প্রয়োগ হতে পারে যা স্বাভাবিকভাবে একই সমস্যার ছোট ইনস্ট্যান্সগুলির মধ্যে বিভক্ত করা যায়। তবে, এটি বেস কেসে সামনে আসার জন্য ফাংশনটি কেমন ডিজাইন করতে হয় তা নিশ্চিত করতে হয় যাতে ফাংশনটি বেস কেসে এসে সেস্থান পেতে এবং অসীম রিকার্সনে পরিণত না হয়। রিকার্সন সাধারণভাবে বিভিন্ন অ্যালগরিদম এবং ডেটা স্ট্রাকচারে ব্যবহৃত হয়,&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--Szu10C_r--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/lek147jvxpfhcaz7pswb.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--Szu10C_r--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/lek147jvxpfhcaz7pswb.png" alt="Image description" width="800" height="760"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  রিকার্সন কীভাবে মেমরিতে সংরক্ষণ করা হয়?
&lt;/h2&gt;

&lt;p&gt;রিকার্সন বেশি মেমরি ব্যবহার করে, কারণ রিকার্সিভ ফাংশন প্রতিটি রিকার্সিভ কলে স্ট্যাকে আরো মান যোগ করে এবং কল শেষ হওয়া পর্যন্ত সেখানে মানগুলি রাখে। রিকার্সিভ ফাংশনটি LIFO (LAST IN FIRST OUT) স্ট্রাকচার ব্যবহার করে, যদি স্ট্যাক ডেটা স্ট্রাকচারের মতো।&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--L2MGwf1t--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/bcod8cet73h7ixafaack.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--L2MGwf1t--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/bcod8cet73h7ixafaack.png" alt="Image description" width="800" height="326"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Recursion হল একটি শক্তিশালী কৌশল যা কম্পিউটার বিজ্ঞান এবং প্রোগ্রামিং-এ অনেক অ্যাপ্লিকেশন রয়েছে। এখানে পুনরাবৃত্তির কিছু সাধারণ অ্যাপ্লিকেশন রয়েছে:&lt;/p&gt;

&lt;p&gt;· ফ্যাক্টোরিয়াল গণনা: পুনরাবৃত্তির মাধ্যমে ফ্যাক্টোরিয়াল গণনা করা যেতে পারে।&lt;/p&gt;

&lt;p&gt;· ক্রমবর্ধমান ফাংশন: পুনরাবৃত্তির মাধ্যমে ক্রমবর্ধমান ফাংশনগুলি গণনা করা যেতে পারে।&lt;/p&gt;

&lt;p&gt;· গাণিতিক সমস্যার সমাধান: পুনরাবৃত্তির মাধ্যমে গাণিতিক সমস্যাগুলি সমাধান করা যেতে পারে।&lt;/p&gt;

&lt;p&gt;· গ্রাফ traversals: পুনরাবৃত্তির মাধ্যমে গ্রাফ traversals করা যেতে পারে।&lt;/p&gt;

&lt;p&gt;· ডেটা কাঠামো: পুনরাবৃত্তির মাধ্যমে ডেটা কাঠামোগুলি তৈরি এবং manipulated করা যেতে পারে।&lt;/p&gt;

&lt;p&gt;· প্রোগ্রামিং ল্যাঙ্গুয়েজ: পুনরাবৃত্তির মাধ্যমে প্রোগ্রামিং ভাষাগুলিতে ফাংশন এবং অন্যান্য constructs defined করা যেতে পারে।&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--gpVlgL8c--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/br1i0ozt1wixloqxo8u2.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--gpVlgL8c--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/br1i0ozt1wixloqxo8u2.jpg" alt="Image description" width="462" height="523"&gt;&lt;/a&gt;&lt;/p&gt;

</description>
      <category>javascript</category>
      <category>programming</category>
      <category>recursion</category>
    </item>
  </channel>
</rss>
