بکندباز

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

او از سمت چپ لیست شروع می‌کند و اعداد را به‌صورت دوتایی مقایسه می‌کند. اگر جفت اول به ترتیب [عدد کوچک‌تر، عدد بزرگ‌تر] باشد، به جفت بعدی می‌رود. اگر جفت اول به ترتیب [عدد بزرگ‌تر، عدد کوچک‌تر] باشد، آن دو عدد را جابجا کرده و سپس به جفت بعدی می‌رود. این فرآیند را تا انتهای لیست تکرار می‌کند.

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

اگر لیست نامرتب [3, 9, 7, 4] باشد، مراحل زیر انجام می‌شود:

  1. اولین جفت [3, 9] مرتب است. حرکت به جفت بعدی. لیست: [3, 9, 7, 4]. تعداد جابجایی‌ها: 0.
  2. جفت [9, 7] مرتب نیست. جابجایی انجام می‌شود. لیست: [3, 7, 9, 4]. تعداد جابجایی‌ها: 1.
  3. جفت [9, 4] مرتب نیست. جابجایی انجام می‌شود. لیست: [3, 7, 4, 9]. تعداد جابجایی‌ها: 2.
  4. بررسی لیست. مرتب نشده است. شروع دوباره از اولین جفت.
  5. جفت [3, 7] مرتب است. حرکت به جفت بعدی. لیست: [3, 7, 4, 9]. تعداد جابجایی‌ها: 2.
  6. جفت [7, 4] مرتب نیست. جابجایی انجام می‌شود. لیست: [3, 4, 7, 9]. تعداد جابجایی‌ها: 3.
  7. جفت [7, 9] مرتب است. حرکت به جفت بعدی. لیست: [3, 4, 7, 9]. تعداد جابجایی‌ها: 3.
  8. بررسی لیست. مرتب است. پایان.

بنابراین، مرتب‌سازی لیست [3, 9, 7, 4] به 3 جابجایی نیاز دارد.

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

نمونه ورودی و خروجی

NumberOfSwaps([5, 4, 3]) ➞ 3

NumberOfSwaps([1, 3, 4, 5]) ➞ 0

NumberOfSwaps([5, 4, 3, 2]) ➞ 6
Assert.Equal(3, Backendbaz.NumberOfSwaps(new int[] { 5, 4, 3 }));
Assert.Equal(0, Backendbaz.NumberOfSwaps(new int[] { 1, 3, 4, 5 }));
Assert.Equal(6, Backendbaz.NumberOfSwaps(new int[] { 5, 4, 3, 2 }));
Assert.Equal(1, Backendbaz.NumberOfSwaps(new int[] { 1, 2, 4, 3 }));
Assert.Equal(3, Backendbaz.NumberOfSwaps(new int[] { 1, 2, 5, 4, 3 }));
Assert.Equal(0, Backendbaz.NumberOfSwaps(new int[] { 1, 3, 4, 5 }));
Assert.Equal(0, Backendbaz.NumberOfSwaps(new int[] { 1, 2 }));

هنوز پاسخی برای این تمرین ثبت نشده است

نظرات

*
*

تمرینات مرتبط