حساب کاربری
​
زمان تقریبی مطالعه: 2 دقیقه
لینک کوتاه

مرتب‌سازی درختی

مرتب‌سازی درختی یک الگوریتم مرتب‌سازی می‌باشد که یک درخت جستجوی دودویی از کلیدهایی که باید مرتب شوند می‌سازد و آنگاه با پیمایش میان ترتیب درخت کلیدهای مرتب شده را بدست می‌آوریم.

مرتب‌سازی درختی
ردهالگوریتم مرتب‌سازی
ساختمان دادهآرایه
کارایی بدترین حالت O ( n 2 ) {\displaystyle O(n^{2})}
(نامتوازن)، O ( n log ⁡ n ) {\displaystyle O(n\log n)}
(متوازن)
کارایی بهترین حالت O ( n ) {\displaystyle O(n)}
(نامتوازن)، O ( n log ⁡ n ) {\displaystyle O(n\log n)}
(متوازن)
کارایی متوسط O ( n log ⁡ n ) {\displaystyle O(n\log n)}
پیچیدگی فضایی Θ ( n ) {\displaystyle \Theta (n)}

فهرست

  • ۱ زمینه کاربرد
  • ۲ تحلیل کارایی
    • ۲.۱ بدترین حالت
  • ۳ غالب پردازش
  • ۴ برنامه نویسی
  • ۵ پانویس
  • ۶ منابع
  • ۷ برای اطلاعات بیشتر

زمینه کاربرد

معمولاً هنگامی از مرتب‌سازی درختی استفاده می‌شود که هدف مرتب‌سازی یک رشته ورودی از یک فایل باشد. در اغلب الگوریتم‌های مرتب‌سازی داده‌ها باید در یک ساختمان داده موقت ذخیره شوند و سپس عملیات مرتب‌سازی بر روی آن انجام شود. در حالیکه در مرتب‌سازی درختی بارگذاری یک عنصر در ساختمان داده بر مرتب‌سازی آن است.

تحلیل کارایی

درج یک عنصر در یک درخت جستجوی دودویی به طور میانگین از مرتبه((O(log(n است. بنابراین ساخت یک درخت جستجوی دودویی با n عضو از مرتبه((O(n log(n می‌باشد که یک درخت جستجو می‌سازدو همچنین یک مرتب‌سازی بهینه است.

بدترین حالت

اضافه کردن ک عنصر جدید به یک درخت جستجوی دودویی از(O(n زمان می‌برد. یعنی هنگامی که درخت شبیه به یک لیست پیوندی ساده می‌شود باعث می‌شود که در بدترین حالت این الگوریتم از مرتبه (O(n زمان می‌برد.
البته با استفاده از گسترش‌هایی از درخت دودویی جستجو می‌توان رفتار بدترین حالت را بهبود داد و در بدترین حالت هم از((O(n log(n باشد. پس مرتب‌سازی درختی به لحاظ تئوری هم بهینه است.

غالب پردازش

غالب پردازش در یک مرتب‌سازی درختی درج در درخت دودویی است با فرض اینکه زمان بازیابی اطلاعات (O(n باشد.

برنامه نویسی

در زیر تکه برنامه سی پلاس پلاس را آورده‌ایم.
multiset کلاسی در سی پلاس پلاس می‌باشد که در حقیقت یک درخت جستجوی دودویی خاص می‌باشد که این امکان را فراهم می‌سازدکه در بدترین حالت هم درج بهینه در این داده ساختار از ((O(log(n داشته باشیم.

#include <set> // for multiset
#include <algorithm> // for copy
#include <iterator> // for iterator_traits
 
template <typename Iterator>
void binary_tree_sort(Iterator begin, Iterator end)
{
    // C++'s multiset class is a self-balancing binary search tree that allows duplicates
    // Add each element in input range to the tree
    std::multiset<typename std::iterator_traits<Iterator>::value_type> tree(begin, end);
 
    // Read elements in ascending order by simply traversing the tree.
    std::copy(tree.begin(), tree.end(), begin);
}

پانویس

  1. ↑ داده ساختارها و مبانی الگوریتم ها-دکتر محمد قدسی-۱۳۸۸ ص۲۲۱

منابع

  • قدسی، محمد. داده ساختارها و مبانی الگوریتم ها. موسسه فرهنگی فاطمی: نشر، ۱۳۸۸.
  • کتاب CLRS

http://www.google.com/url?sa=t&source=web&ct=res&cd=10&ved=0CDUQFjAJ&url=http://www.cs.sjsu.edu/~lee/cs146/24SpL8binarytree2.ppt&ei=h2rgS6atMYP48AaMnaSlBw&usg=AFQjCNG7QyTODSQHwsEagIMXQYTduDkyoQ

http://www.knowledgerush.com/kr/encyclopedia/Binary_tree_sort

برای اطلاعات بیشتر

  • Binary Tree Java Applet and Explanation
آخرین نظرات
کلیه حقوق این تارنما متعلق به فرا دانشنامه ویکی بین است.