ধরুন আমাদের একটি ধনাত্মক পূর্ণসংখ্যা L আছে, যা একটি নিখুঁত বাইনারি গাছের স্তরের সংখ্যাকে প্রতিনিধিত্ব করে। এই নিখুঁত বাইনারি গাছের পাতার নোডগুলি 1 থেকে n পর্যন্ত সংখ্যাযুক্ত। যেখানে n হল পাতার নোডের সংখ্যা। প্যারেন্ট নোড হল শিশুদের সমষ্টি। আমাদের কাজ হল এই নিখুঁত বাইনারি গাছের সমস্ত নোডের যোগফল প্রিন্ট করার জন্য একটি প্রোগ্রাম লেখা। তাই যদি গাছটি নিচের মত হয় -

সুতরাং মোট যোগফল 30।
যদি আমরা কাছাকাছি দেখি, আমাদের সমস্ত নোডের যোগফল খুঁজে বের করতে হবে। যেহেতু লিফ নোডগুলি 1 থেকে n পর্যন্ত মান ধারণ করে, তাই আমরা লিফ নোডের যোগফল পেতে n(n+1)/2 সূত্রটি ব্যবহার করতে পারি। যেহেতু এটি নিখুঁত বাইনারি গাছ, তাই প্রতিটি স্তরের যোগফল একই হবে। তাই শেষ স্তরের যোগফল বের করুন, তারপর এটিকে স্তরের সংখ্যা দিয়ে গুণ করুন।
উদাহরণ
#include<iostream>
#include<cmath>
using namespace std;
int treeSum(int level) {
int total_leaves = pow(2, level - 1);
int leaf_sum = 0;
leaf_sum = (total_leaves * (total_leaves + 1)) / 2;
int sum = leaf_sum * level;
return sum;
}
int main() {
int levels = 4;
cout << "Sum of all nodes for a perfect binary tree with level " << levels << " is: " << treeSum(levels);
} আউটপুট
Sum of all nodes for a perfect binary tree with level 4 is: 144