الگوریتم دی-استوت-وارن

الگوریتم Day-Stout-Warren یا به اختصار (DSW) یک روش مؤثر برای متوازن کردن درخت جستجوی دودویی است، که در آن ارتفاع درخت را تا (O(log n کاهش می‌دهد، در حالی که n تعداد کل رأس‌ها ست. بر خلاف یک درخت جستجوی دودویی خود-متوازن این کار را تدریجاً در هر کدام از مراحل انجام نمی‌دهد، بلکه در دوره‌های معین عملیات را انجام می‌دهد، به نحوی که هزینه کل می‌تواند به تمام مراحل انجام شده سرشکن شود. این الگوریتم توسط Quentin F. Stout و Bette Warren در مقاله‌ای با عنوان Tree Rebalancing in Optimal Time and Space در سال ۱۹۸۶ طراحی شد که براساس یک تحقیق انجام شده توسط Colin Day در سال ۱۹۷۶ بود.
زمان اجرا این الگوریتم خطی ست (یعنی از مرتبه (O(nاست). الگوریتم اصلی طراحی شده توسط Day، متراکم‌ترین درخت ممکن را تولید می‌کند: تمام سطرهای درخت کامل هستند به جز سطر آخر.ولی این اصلاح توسط Stout/Warren یک درخت دودویی کامل تولید می‌کند. به عبارت دیگر یک درخت که در آن پایین‌ترین سطح از سمت چپ به راست کاملاً پر شده‌است. این یک تبدیل خوب است در صورتی که معلوم باشد درج دیگری در درخت انجام نمی‌شود.
اخیر ا مقاله‌ای در سال ۲۰۰۲ که توسط Timothy J. Rolfe تألیف شده‌است که بعد از مدت زیادی توجهات را به الگوریتم DSW جلب کرده‌است. نام گذاری بر اساس عنوان یک بخش از "6.7.1: The DSW Algorithm" در کتاب Data Structures and Algorithms in C++ (انتشارات PWS در صفحات ۱۷۳-۱۷۵) نوشته شدهٔ Adam Drozdek، انجام شده‌است. Rolfe دو مزیت اصلی برای آن ذکر می‌کند: "در موقعیت‌هایی که یک درخت جستجوی دودویی کامل در ابتدای مراحل تولید میشود که این درخت با دسترسی به وارسی تکه‌های گوناگون برای بقیه مراحل پردازش دنبال می‌شود" و بعدی اینکه "از لحاظ آموزشی در مباحث ساختمان داده و ریاضیات گسسته،پیشرفت خوبی در زمینه ی درخت های خودمتوازن برای چرخش درخت های دودویی ارائه میدهد. "

منابع

    This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.