الگوریتم استینهوس-جانسون-تروتر
الگوریتم استینهوس-جانسون-تروتر (به انگلیسی: Steinhaus–Johnson–Trotter algorithm) الگوریتمی برای یافتن یک شیوه از قرار دادن جایگشت به طول پشت سر یکدیگر است به طوری که هر جایگشت در این ترتیب با جابجا کردن دو عنصر مجاور در جایگشت قبلیاش به دست میآید.
نام این الگوریتم بر اساس نام سه دانشمند هوگو استینهوس، سلمر مارتین جانسون و هیلفریمن تروتر بودهاست که تقریباً در زمانی نزدیک و به صورت مجزا از هم به این الگوریتم رسیده بودند.
این الگوریتم برای ساختن ترتیبی از جایگشتها در قرن ۱۷ام شناخته شد و رابرت سجدویک[۱] نیز به سرعت و سادگی این الگوریتم اشاره کردهاست.
دیدگاه از منظر گرافها
[ویرایش]
ابن مسئله معادل یافتن یک مسیر هامیلتونی در یک گراف است.
گراف را به این شکل میسازیم که برای هر یک از جایگشت موجود یک راس قرار دهیم و سپس بین دو راس یال میگذاریم اگر با یکبار جابجا کردن دو عنصر مجاور بتوانیم یکی را به دیگری تبدیل کنیم، به این گراف، گراف جایگشتها میگویند.
مثلاً برای ، جایگشت به یال دارد ولی به
یال ندارد.
اکنون اگر بتوانیم مسیری هامیلتونی در این گراف بیابیم، در این صورت ترتیب پیمایش گراف، همان تعریف مطلوب است. الگوریتم مورد بحث نیز یک مسیر معتبر ارائه میدهد.
شیوه استقرایی در یافتن دنباله جایگشتها
[ویرایش]- برای که مسئله واضح است و تک جایگشت ترتیب مطلوب است.
- اکنون فرض میکنیم میتوانیم ترتیبی از جایگشت بیابیم و ترتیبی برای جایگشتهای به طول پیدا میکنیم.
فرض کنید ترتیب در فرض استقرا باشد. اکنون را به این شکل تعریف میکنیم.
- چنانچه زوج باشد، جایگشتی است که از اضافه کردن به جایگاه ام به دست میآید.
- چنانچه فرد باشد، جایگشتی است که از اضافه کردن به جایگاه جایگشت به دست میآید.
اکنون ترتیب مطلوب برای جایگشتهای به طول را به این شکل میسازیم.
برای مثال اگر برای ترتیبی که فرض استقرا به ما میدهد، باشد، در اینصورت و با ساختن ها، ترتیب مطلوب برای به شکل
خواهد بود.
اثبات
[ویرایش]اکنون درستی این دنباله را نشان میدهیم. دو عنصر متوالی از دنباله را در نظر میگیریم و نشان میدهیم که با یک عملیات جابجایی دو عنصر مجاور به یکدیگر تبدیل میشوند. فرض کنید دو جایگشت و را در نظر بگیریم دو حالت متصور است.
- اگر این دو جایگشت به شکل باشند، در اینصورت اگر را از دو جایگشت حذف کنیم جایگشت یکسان به دست میآید؛ و دو جایگشتی که ما بررسی میکنیم از اضافه کردن به دو جایگاه متوالی از به دست میآید. پس با جابجا کردن با عنصر کنارش از جایگشت به جایگشت میرسیم.
- اگر اگر این دو جایگشت به شکل باشد، در این صورت در تعریف ما، در هر دو این جایگشتها در یک سمت جایگشت است و بقیه جایگشت (بدون در نظر گرفتن ) جایگشتهای هستند که طبق فرض استقرا با یک عملیات به یکدیگر تبدیل میشوند.
برای اینکه اثبات کامل شود، لازم است نشان دهیم که جایگشتهایی که تولید میکنیم متمایزند. برای مثال را در نظر بگیرید.
- اگر در اینصورت چون مکان در این دو جایگشت تفاوت میکند لذا دو جایگشت متفاوتند.
- اگر ، در اینصورت جایگشتهایی که با حذف به دست میآید هستند که طبق فرض استقرا با یکدیگر متفاوتند لذا دو جایگشت نیز متفاوتند.
الگوریتم
[ویرایش]الگوریتمی که در سال ۱۹۶۳ منتشر شد، دقیقاً ترتیب بالا را تولید میکند ولی نیازی به حل مسئله برای مقادیر کمتر و تولید دنبالههای کوچکتر ندارد و به شکلی مستقیم و با شروع از حالت اولیه همه جایگشتها را تولید میکند.[۲][۱][۳]
برای هر عدد در جایگشت یک جهت تعریف میشود که یا بهراست است یا بهچپ. در ابتدا جایگشت است و همه جهتها به چپ هستند.
سپس در هر گام یک mobile تعریف میکنیم که به این صورت محاسبه میشود.
- بزرگترین عددی است که از عدد سمت جهتش، بزرگتر است (یعنی برای اعدادی که جهتشان بهچپ است آن را با عدد سمت چپش و برای اعدادی که جهتشان بهراست است آن را با عدد سمت راستش مقایسه میکنیم) در میان اعدادی که از عدد مربوطهشان بزرگترند، بزرگترین را در نظر میگیریم و این عدد را mobile مینامیم.
- سپس این عدد را با عددی که جهتش اشاره میکند (یعنی همان عددی که با آن مقایسه شدهاست) جابجا میکنیم.
- در گام آخر، جهت همه اعدادی که از mobile بزرگترند را برعکس میکنیم. یعنی از بهچپ به بهراست و بالعکس.
هنگامی که دیگر mobile در جایگشت پیدا نشد، الگوریتم پایان مییابد و جایگشتهای تولید شده در این میان، ترتیب مطلوب ما هستند.
فرایند را برای ببینید.
mobile = ۳
mobile = ۳
mobile = ۲
mobile = ۳
mobile = ۳
دیگری mobile وجود ندارد. الگوریتم پایان مییابد.
مجدداً درستی الگوریتم با استقرا ثابت میشود.
پیچیدگی زمانی الگوریتم
[ویرایش]در این الگوریتم جایگشت تولید میشود که برای هر کدام هزینه برای یافتن mobile و جابجاییها و برعکسکردن جهتها لازم است؛ لذا هزینه الگوریتم خواهد بود.
ارتباط با کد گِرِی
[ویرایش]کدگری در حالت کلی، ترتیبی از اعداد رقمی در مبنایی دلخواه است، طوری که هر دو عدد مجاور در دقیقاً یک رقم تفاوت داشته باشند.
اکنون به هر جایگشت یک دنباله متناظر میکنیم و ادعا میکنیم که دنبالههای تولید شده توسط الگوریتمِ (که در مبنای فاکتوریل هستند)، خاصیت کدگری را دارند.
برای هر جایگشت یک دنباله ، تعریف میکنیم که به این شکل حساب میشود.
- را برابر تعداد اعداد کوچکتر از ، در سمت راست در جایگشت تعریف میکنیم.
مثلاً دنباله مربوطه برای برابر با خواهد بود.
ابتدا نشان میدهیم که برای جایگشتهای متفاوت دنباله نیز متفاوت خواهد بود.
نشان میدهیم دنباله جایگشتی یکتا تولید میکند.
را در نظر بگیرید، به سادگی میتوان دریافت که در جایگشت جایگاه عدد ، برابر با است. اکنون عدد را حذف کنید و به شکلی بازگشتی بقیه اعداد را به شکل یکتا در جایگاههایشان قرار دهید، تا همه اعداد در جایگشت قرار گیرند، در تمامی مراحل فرایند یکتاست، پس تنها یک جایگشت خاص، دنباله متناظرش است.
میتوان نشان داد ترتیبی که الگوریتم جانسون-تروتر تولید میکند دنبالههای میسازد که خاصیت کد گری را دارند، یعنی هر دو دنباله متوالی دقیقاً در یک رقم تفاوت دارند. (برای اثبات میتوانید نشان دهید که اگر دو عضو متوالی از یک جایگشت را جابجا کنیم دقیقاً یکی از تغییر میکند)[۴][۵]
برای ،
جایگشتها
هستند که دنبالههای متناظر با آنها برابر با
است
و همانطور که مشاهده میشود، دنباله تولید شده خاصیت کد گری را دارد.
جستارهای وابسته
[ویرایش]منابع
[ویرایش]- ↑ ۱٫۰ ۱٫۱ (Sedgewick, Robert (1977), "Permutation generation methods", ACM Comput. Surv., 9 (2): 137–164 و doi:10.1145/356689.356692).
- ↑ (Dershowitz, Nachum (1975), "A simplified loop-free algorithm for generating permutations", Nordisk Tidskr. Informationsbehandling (BIT), 15 (2): 158–164. و doi:10.1007/bf01932689, MR 0502206)
- ↑ (Ehrlich, Gideon (1973), "Loopless algorithms for generating permutations, combinations, and other combinatorial configurations", Journal of the ACM, 20 (3): 500–513. و doi:10.1145/321765.321781)
- ↑ (Knuth, Donald (2011), "Section 7.2.1.2: Generating All Permutations", he Art of Computer Programm. و volume 4A)
- ↑ (Dijkstra, Edsger W. (1976), "On a gauntlet thrown by David Gries", Acta Informatica, 6 (4): 357–359, doi:10.1007/BF00268136, MR 0426492. و Although DIjkstra does not cite any prior literature, an earlier draft EWD502 reveals that he knew of Trotter (1962))