১৮-৫ঃ Count Number of Nodes of a Binary Tree
গত মডিউলে আমরা দেখেছি , কীভাবে একটি Binary Tree ইনপুট নেয়া যায়। ইনপুট নেয়ার পর এই মডিউলে আমরা দেখবো , একটি বাইনারী ট্রি তে কয়টি Node আছে তা কাউন্ট করা যায় ।
Binary Tree এর Node সংখ্যা কাউন্ট করা সহজ একটি কাজ যদি আমরা Recursion ভালো মতো বুঝে থাকি । আমরা জানি Recursion এর মাধ্যমে আমরা একটি কাজ বারবার ঐ ফাংশন কল করার মাধ্যমে করে নিতে পারি। এইক্ষেত্রেও ঠিক একই ভাবে শুধুমাত্র একটি ফাংশনের সাহায্যে আমরা Node কাউন্ট করার কাজটি করে নিতে পারবো । তার জন্য শুধু মাত্র প্রয়োজন ঠিক মতো Recursion ব্যবহার করতে পারা , and most importantly বুঝতে পারা আমাদের যে ফাংশন টি আছে তার কাজটা কী। আমরা যেহেতু একটি Binary tree এর Node সংখ্যা কাউন্ট করবো , তাই আমাদের ফাংশনের কাজ হবে যদি তাকে একটি Root Node দিয়ে দেয়া হয় তবে সে ঐ Root এর Binary Tree তে কয়টি Node আছে তা আমাদের রিটার্ন করে দিবে । এখন আমরা কিছু Question করার মাধ্যমে আমাদের Recursion ফাংশন টি তৈরি করবো ।
প্রথমত , আমরা যদি Binary Tree এর Node টি ফাংশনে পাস করি , এবং Root যদি Null না হয় , তবে আমরা এতটুকু নিশ্চিত যে , আমরা মিনিমাম একটি Node তো পেয়েছি ।
এরপর , দেখার বিষয় হলো তার Left Subtree তে কয়টি Node আছে এবং তার Right subtree তে কয়টি Node আছে ।
যেহেতু আমরা আমাদের ফাংশন কে এমন ভাবে ডিজাইন করেছি , তাকে একটি Root Node দেয়া হলে সে আমাকে ঐ Binary Tree তে কয়টি Node আছে তা বের করে দিবে , তাই আমরা নতুন করে আর ফাংশন না লিখে Left subtree এর Root Node একই ফাংশনে pass করে তা বের করে নিতে পারবো। এক্ষেত্রে Left subtree এর Root অর্থাৎ Main Root এর Left child টি থেকে যে Tree উৎপন্ন হয়েছে , তাকে আমরা একটি Subtree বলতেছি .
Right subtree তে কয়টি Node আছে তা বের করার জন্য আমরা একইভাবে আমাদের কাউন্ট করার ফাংশনটির হেল্প নিবো এবং তাকে Right subtree এর Root Node টি পাস করলে আমরা ঐ Subtree তে কয়টি Node আছে তা আমাকে বের করে দিবে । এক্ষেত্রে Right subtree এর Root অর্থাৎ Main Root এর Right child টি থেকে যে Tree উৎপন্ন হয়েছে , তাকে আমরা একটি Subtree বলতেছি .
সবশেষে Left Subtree তে কয়টি Node আছে এবং Right Subtree তে কয়টি Node আছে তা জানার পর , আমরা Main Root Node এর জন্য ১ যোগ করে , পুরো Binary Tree তে কয়টি Node আছে তা রিটার্ন করে দিতে পারি।
খেয়াল রাখতে হবে , ফাংশনের base case যাতে ঠিক মতো সেট করা থাকে। এখন চিন্তা করে দেখা যাক , Base case কী হতে পারে । প্রথমে আমরা চিন্তা করতেসিলাম , যদি Root Node টি null নাহয় তবে সেক্ষেত্রে আমরা একটি হলেও Node পাবো তা guaranteed. এখন Root যদি নিজেই Null হয় তবে সেক্ষেত্রে তার তো কোনো Children থাকবে না , যেহতু তার ই কোনো অস্তিত্ব নেই। এক্ষেত্রে আমরা left এ কয়টি Node আছে বা right এ কয়টি Node আছে তা না দেখে সরাসরি 0 return করতে পারি। কারণ এই Tree তে কোনো Node ই নেই। আসুন , এইবার সহজ সরল এই approach এর কোডটি লিখে ফেলা যাক।
Last updated