پیوندهای رقصنده

در علوم کامپیوتر، پیوندهای رقصنده تکنیکی است که توسط "دانلد کنوت (Donald Knuth)" پیشنهاد شده‌است تا الگوریتم X اش را به طور مؤثر پیاده‌سازی نماید. الگوریتم X یک الگوریتم بازگشتی، غیرقطعی، اول‌عمق و الگوریتمی است که لیست را به طور معکوس می‌پیماید که همهٔ راه‌حل‌ها را برای پوشش دقیق مسئله پیدا می‌کند. بعضی از پوشاننده‌های دقیق مسئله که شناخته‌شده‌تر اند شامل موزائیک‌کاری، مسئله چند وزیر و سودوکو.

ریشهٔ لغوی اسم پیوندهای رقصنده از روش عملکرد الگوریتم بدست می‌آید. همان‌طور که تکرار الگوریتم باعث می‌شود که یک پیوند با پیوند کناری خود برقصد که آن را می‌توان به لطافت رقص باله تشبیه نمود. دانلد کنوت به Hiroshi Hitotsumatsu و Kōhei Noshita برای ایده‌ای که در سال ۱۹۷۹ ساخته شد اعتبار این مقاله را داد، اما مقالهٔ خود او است که این موضوع را مشهور کرده است.

پیاده‌سازی

در ادامهٔ این مقاله در مورد جزئیات تکنیک‌های پیاده‌سازی برای الگوریتم X صحبت می‌کنیم، خواننده به شدت تشویق می‌شود که ابتدا مقالهٔ الگوریتم X را مطالعه کند.

ایده‌های اصلی

ایدهٔ DLX بر پایهٔ مشاهدهٔ فهرست پیوندی دوطرفه حلقوی از ریشه‌ها شکل گرفت.

;x.left.right ← x.right
;x.right.left ← x.left

ریشهٔ X را از لیست حذف خواهد نمود، هنگامی که

;x.left.right ← x
;x.right.left ← x

موقعیت X در لیست را ذخیره‌سازی می‌کند، با فرض اینکه عنصر راست X و عنصر چپ X بدون تغییر باقی مانده‌اند. این کار صرف‌نظر از عدد عناصر در لیست می‌باشد، حتی اگر آن عدد ۱ باشد.

دانلد کنوت مشاهده کرد که یک پیاده‌سازی ساده از الگوریتم X مقدار بی‌شماری از زمان را برای جستجوی ۱ صرف می‌کند. وقتی که یک ستون را انتخاب می‌کنیم، کل ماتریس باید برای ۱ مورد جستجو قرار گیرد. وقتی که یک ردیف را انتخاب می‌کنیم، کل ستون باید برای ۱ مورد جستجو قرار گیرد. بعد از انتخاب یک ردیف، آن ردیف و تعداد ستون‌ها باید برای ۱ مورد جستجو قرار گیرند. برای بهبود دادن این زمان جستجو از پیچیدگی O(n) تا O(1)، دانلد کنوت یک ماتریس خلوت را پیاده‌سازی کرد جایی که فقط ۱ ذخیره شده است.

در همهٔ اوقات، هر گره در ماتریس اشاره می‌کند به گره‌های مجاور در چپ و راست (۱ در همان ردیف)، در بالا و پایین (۱ در همان ستون)، و سر آن ستون (در پایین توضیح داده شده‌است). هر ردیف و ستون در ماتریس شامل یک لیست پیوند دوتایی حلقوی از گره‌ها خواهندشد.

سر

سر هر ستون یک گره خاص خواهد داشت که به عنوان سرستون شناخته شده‌است، آن که در ستون لیست شامل می‌شود، و یک ردیف مخصوص را شکل خواهدداد ("ردیف کنترل") شامل همهٔ ستون‌هایی می‌شود که هنوز در ماتریس وجود دارند. در آخر، هر سرستون ممکن است به طور انتخابی تعداد گره‌ها در ستون خود را پیدا کند، بنابراین موقعیت یابی یک ستون با کمترین تعداد گره از پیچیدگی O(n) نسبت به O(n*m) است که n تعداد ستون‌ها و m تعداد سطرها می‌باشد. انتخاب کردن ستون با کم‌ترین شمار گره یک کار غیرمستدل است که کارایی را در همان مورد افزایش می‌دهد، ولی در الگوریتم ضروری نمی‌باشد.

کاوش

در الگوریتم X، ردیف‌ها و ستون‌ها مرتباً از ماتریس حذف و به آن بازگردانده می‌شوند. عملیات حذف توسط انتخاب کردن ستون و سطر در آن ستون تعیین شده‌است. اگر یک ستون انتخاب شده هیچ ردیفی نداشت، ماتریس کنونی غیرقابل‌حل است و باید رد گم می‌کرد. وقتی عملیات حذف رخ می‌دهد، همهٔ ستون‌ها برای ردیف انتخاب شده که شامل ۱ است حذف شده‌اند، در طول همهٔ ردیف‌ها (شامل ردیف انتخاب شده) که شامل یک ۱ در همهٔ ستون‌های حذف‌شده است. ستون‌ها حذف شده‌اند زیرا پر شده‌اند، و ردیف‌ها حذف شده‌اند زیرا با ردیف انتخاب‌شده در تضادند. برای حذف کردن یک ستون تنها، ابتدا سرستون انتخاب شده را حذف کنید. بعد، برای هر ردیف که ستون انتخاب شده شامل یک ۱ می‌باشد، در ردیف پیمایش کنید و از ستون دیگر حذف کنید (این ردیف‌های دیگر را غیرقابل‌دسترس می‌کند و این چگونگی جلوگیری از تضاد می‌باشد). این تفکیک ستون را برای هر ستون تکرار کنید جایی که ردیف انتخاب شده شامل یک ۱ باشد. این ترتیب انجام کار اطمینان می‌دهد که هر گرهٔ حذف شده دقیقاً یک‌بار حذف شده است و در یک حالت انجام کار قابل پیشبینی، بنابراین این می‌تواند به طور مناسب عمل پیمایش معکوس لیست را انجام دهد. اگر ماتریس نتیجه هیچ ستونی نداشت، بنابراین همهٔ آن‌ها پر می‌شوند و ردیف انتخاب شده از راه‌حل.

عمل پیمایش معکوس یک لیست

برای پیمایش معکوس لیست، فرایند بالا باید معکوس شود و از توضیح الگوریتم دوم بالا استفاده کند. یکی از لازمه‌های استفاده از آن الگوریتم این است که عمل پیمایش معکوس باید به طور دقیق معکوس عمل حذف انجام شود. مقالهٔ دانلد کنوت یک تصویر واضح از این روابط و چگونگی عملکرد تفکیک گره می‌دهد و مقدار ناچیزی آسایش از این محدودیت را آماده می‌کند.

محدودیت‌های اختیاری

همچنین این نیز ممکن است که برای حل مسایل یک پوششی که محدودیت مشخصی به صورت اختیاری است؛ ولی می‌تواند متقاعد شود نه بیشتر از یک‌بار. پیوندهای رقصنده این‌ها را با ستون‌های اولی که باید پر شوند تطابق می‌دهند و ستون‌های ثانویه که اختیاری هستند. این تست راه‌حل الگوریتم را تغییر می‌دهد از یک ماتریسی که هیچ ستونی ندارد به ماتریسی که هیچ ستون اولیه‌ای ندارد و اگر کشف کنندهٔ مینیمم یکم در یک ستون مورد استفاده قرار گرفت سپس آن نیاز دارد که تنها در طول ستون ابتدایی چک شود. دانلد کنوت در مورد محدودیت‌های اختیاری بحث می‌کند مانند کاربرد مسئله چند وزیر. قطر صفحه شطرنجی محدودیت‌های اختیاری را نشان می‌دهد، همانند بعضی از قطرها ممکن است اشغال نشود. اگر یک قطر اشغال شده‌است، آن تنها یک‌بار می‌توان اشغال شود.

منابع

دانلد کنوت(۲۰۰۰). پیوندهای رقصنده. منظر جشن هزار ساله در علوم کامپیوتر. P159 187. آرخیو: cs/0011047. بازیافته شده ۲۰۰۶-۰۷-۱۱.

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