پرش به محتوا

الگوریتم استینهوس-جانسون-تروتر

از ویکی‌پدیا، دانشنامهٔ آزاد

الگوریتم استینهوس-جانسون-تروتر (به انگلیسی: Steinhaus–Johnson–Trotter algorithm) الگوریتمی برای یافتن یک شیوه از قرار دادن جایگشت به طول پشت سر یکدیگر است به طوری که هر جایگشت در این ترتیب با جابجا کردن دو عنصر مجاور در جایگشت قبلی‌اش به دست می‌آید.
نام این الگوریتم بر اساس نام سه دانشمند هوگو استینهوس، سلمر مارتین جانسون و هیل‌فریمن تروتر بوده‌است که تقریباً در زمانی نزدیک و به صورت مجزا از هم به این الگوریتم رسیده بودند.

این الگوریتم برای ساختن ترتیبی از جایگشت‌ها در قرن ۱۷ام شناخته شد و رابرت سجدویک[۱] نیز به سرعت و سادگی این الگوریتم اشاره کرده‌است.

دیدگاه از منظر گراف‌ها

[ویرایش]
مسیری همیلتونی در این گراف که الگوریتم فوق تولید می‌کند


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

شیوه استقرایی در یافتن دنباله جایگشت‌ها

[ویرایش]
  • برای که مسئله واضح است و تک جایگشت ترتیب مطلوب است.
  • اکنون فرض می‌کنیم می‌توانیم ترتیبی از جایگشت بیابیم و ترتیبی برای جایگشت‌های به طول پیدا می‌کنیم.

فرض کنید ترتیب در فرض استقرا باشد. اکنون را به این شکل تعریف می‌کنیم.

  • چنان‌چه زوج باشد، جایگشتی است که از اضافه کردن به جایگاه ام به دست می‌آید.
  • چنانچه فرد باشد، جایگشتی است که از اضافه کردن به جایگاه جایگشت به دست می‌آید.


اکنون ترتیب مطلوب برای جایگشت‌های به طول را به این شکل می‌سازیم.

برای مثال اگر برای ترتیبی که فرض استقرا به ما می‌دهد، باشد، در این‌صورت و با ساختن ها، ترتیب مطلوب برای به شکل






خواهد بود.

اثبات

[ویرایش]

اکنون درستی این دنباله را نشان می‌دهیم. دو عنصر متوالی از دنباله را در نظر می‌گیریم و نشان می‌دهیم که با یک عملیات جابجایی دو عنصر مجاور به یکدیگر تبدیل می‌شوند. فرض کنید دو جایگشت و را در نظر بگیریم دو حالت متصور است.

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


برای اینکه اثبات کامل شود، لازم است نشان دهیم که جایگشت‌هایی که تولید می‌کنیم متمایزند. برای مثال را در نظر بگیرید.

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

الگوریتم

[ویرایش]

الگوریتمی که در سال ۱۹۶۳ منتشر شد، دقیقاً ترتیب بالا را تولید می‌کند ولی نیازی به حل مسئله برای مقادیر کمتر و تولید دنباله‌های کوچک‌تر ندارد و به شکلی مستقیم و با شروع از حالت اولیه همه جایگشت‌ها را تولید می‌کند.[۲][۱][۳]
برای هر عدد در جایگشت یک جهت تعریف می‌شود که یا به‌راست است یا به‌چپ. در ابتدا جایگشت است و همه جهت‌ها به چپ هستند.
سپس در هر گام یک mobile تعریف می‌کنیم که به این صورت محاسبه می‌شود.

  1. بزرگترین عددی است که از عدد سمت جهتش، بزرگتر است (یعنی برای اعدادی که جهتشان به‌چپ است آن را با عدد سمت چپش و برای اعدادی که جهت‌شان به‌راست است آن را با عدد سمت راستش مقایسه می‌کنیم) در میان اعدادی که از عدد مربوطه‌شان بزرگترند، بزرگ‌ترین را در نظر می‌گیریم و این عدد را mobile می‌نامیم.
  2. سپس این عدد را با عددی که جهتش اشاره می‌کند (یعنی همان عددی که با آن مقایسه شده‌است) جابجا می‌کنیم.
  3. در گام آخر، جهت همه اعدادی که از mobile بزرگترند را برعکس می‌کنیم. یعنی از به‌چپ به به‌راست و بالعکس.

هنگامی که دیگر mobile در جایگشت پیدا نشد، الگوریتم پایان می‌یابد و جایگشت‌های تولید شده در این میان، ترتیب مطلوب ما هستند.

فرایند را برای ببینید.

mobile = ۳


mobile = ۳


mobile = ۲


mobile = ۳


mobile = ۳


دیگری mobile وجود ندارد. الگوریتم پایان می‌یابد.
مجدداً درستی الگوریتم با استقرا ثابت می‌شود.

پیچیدگی زمانی الگوریتم

[ویرایش]

در این الگوریتم جایگشت تولید می‌شود که برای هر کدام هزینه برای یافتن mobile و جابجایی‌ها و برعکس‌کردن جهت‌ها لازم است؛ لذا هزینه الگوریتم خواهد بود.

ارتباط با کد گِرِی

[ویرایش]

کدگری در حالت کلی، ترتیبی از اعداد رقمی در مبنایی دلخواه است، طوری که هر دو عدد مجاور در دقیقاً یک رقم تفاوت داشته باشند.
اکنون به هر جایگشت یک دنباله متناظر می‌کنیم و ادعا می‌کنیم که دنباله‌های تولید شده توسط الگوریتمِ (که در مبنای فاکتوریل هستند)، خاصیت کدگری را دارند.
برای هر جایگشت یک دنباله ، تعریف می‌کنیم که به این شکل حساب می‌شود.

  • را برابر تعداد اعداد کوچکتر از ، در سمت راست در جایگشت تعریف می‌کنیم.

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

می‌توان نشان داد ترتیبی که الگوریتم جانسون-تروتر تولید می‌کند دنباله‌های می‌سازد که خاصیت کد گری را دارند، یعنی هر دو دنباله متوالی دقیقاً در یک رقم تفاوت دارند. (برای اثبات می‌توانید نشان دهید که اگر دو عضو متوالی از یک جایگشت را جابجا کنیم دقیقاً یکی از تغییر می‌کند)[۴][۵]
برای ، جایگشت‌ها
هستند که دنباله‌های متناظر با آن‌ها برابر با
است و همان‌طور که مشاهده می‌شود، دنباله تولید شده خاصیت کد گری را دارد.

جستارهای وابسته

[ویرایش]

منابع

[ویرایش]