2001-gre-vs-practice.pdf/Q52 — различия между версиями

Материал из DISCOPAL
Перейти к: навигация, поиск
Строка 1: Строка 1:
 
{{reserve-task|[[Участник:Илья52|илья52]] 19:05, 22 декабря 2024 (UTC)}}== Вопрос: Q52-e5724f ==
 
{{reserve-task|[[Участник:Илья52|илья52]] 19:05, 22 декабря 2024 (UTC)}}== Вопрос: Q52-e5724f ==
  
<blockquote>
+
Какой из следующих алгоритмов сортировки имеет время выполнения, НАИМЕНЕЕ зависящее от первоначального
Тут вставьте перевод вопроса.
+
порядка ввода?
Используйте [https://wiki.4intra.net/Help:%D0%A4%D0%BE%D1%80%D0%BC%D0%B0%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5 возможности разметки],  
+
включая формулы и т.п, если будут графы — посмотрите как задать их текстом https://wiki.4intra.net/Graphviz (реально оценю, полезный навык).
+
Если код — теги «code-pascal», «code-c» или «code-python» (не «source lang»).
+
  
В IT вообще не принято писать романы, всегда старайтесь писать структурированные (списками-абзацами тексты). Списки в MediaWiki — это просто «*». Не забывайте о них.
+
=== Ответы ===
Преформатированный моноширинный текст — просто отступ.
+
  
Старайтесь нетривиальные понятия, особенно незнакомые вам, найти ссылку на википедию и вставить (нейросети лажают!).
 
Это важно, чтобы найти корректный перевод (то, что в википедии, или на худой конец — точно массово гуглится).
 
  
Потом конечно сотрите эти инструкции, которые тут курсивом или в блоке цитирования.
+
* Сортировка вставками
</blockquote>
+
* Быстрая сортировка
 +
* Правильный ответ: Сортировка слиянием
 +
* Сортировка выбором
 +
* Сортировка Шелла
  
=== Ответы ===
+
=== Объяснение ===
<i>Если ответы простые, однострочные, используйте простой способ задания ответов списком, типа так
+
{{cstest-source|2001-gre-vs-practice.pdf|39|52}}
(префикс «Правильный ответ:» — это дословно, для правильного ответа, неважно, какой он будет в списке)</i>
+
  
* Правильный ответ: тут реально правильный ответ
+
Сортировка вставками: В лучшем случае, когда данные уже отсортированы, имеет время выполнения <m>\bigO{n}</m>. В худшем случае (когда данные отсортированы в обратном порядке) — O(n²).
* неправильный ответ
+
* еще какой-то неправильный ответ
+
* еще какой-то неправильный ответ
+
* еще какой-то неправильный ответ
+
  
<i>Если ответы длинные, многострочные, или там графы, используйте
+
Быстрая сортировка: В среднем случае имеет время выполнения O(n log n), но в худшем случае (если выбор опорного элемента неудачен) — O(n²). Однако, в лучшем случае также может быть O(n log n).
[https://wiki.4intra.net/MediawikiQuizzer/ru#.D0.9E.D1.82.D0.B2.D0.B5.D1.82.D1.8B способ задания ответов разделами],  
+
Но такое очень редко встречается, например [[2011-gre-cs-practice-book.pdf/Q05]]. </i>
+
  
 +
3. Merge sort (Сортировка слиянием): Всегда имеет время выполнения O(n log n), независимо от первоначального порядка данных.
  
=== Объяснение ===
+
4. Selection sort (Сортировка выбором): Всегда имеет время выполнения O(n²), независимо от порядка данных.
<i>Сначала заполните номер страницы с этим вопросом
+
{{cstest-source|2001-gre-vs-practice.pdf|тут-номер-страницы-с-вопросом-52|52}}
+
 
+
Если все сделаете правильно, по ссылке выше будет открываться правильная страница в правильном PDFе.
+
  
Ну и наконец, вики-разметкой напишите ваше понимание, почему правильный ответ — правильный, а [[2004-gre-cs-practice-book.pdf/Q16|неправильные варианты — неправильны]].
+
5. Shellsort: Время выполнения зависит от выбранной последовательности шагов, но в среднем может достигать O(n log n). В худшем случае может быть O(n^(3/2)) или даже O(n²) в зависимости от реализации.
Тут тоже могут быть полезны [[2004-gre-cs-practice-book.pdf/Q03|ссылки на википедию]],
+
решение вами [[2004-gre-cs-practice-book.pdf/Q12|рекуррентных уравнений в sympy]].
+
  
</i>
+
Таким образом, алгоритм с наименьшим временем выполнения, зависимым от первоначального порядка ввода, — это Merge sort, так как его время выполнения всегда составляет O(n log n).
  
 
{{question-ok|}}
 
{{question-ok|}}
  
 
[[Категория:Надо не забыть выбрать тему]]
 
[[Категория:Надо не забыть выбрать тему]]

Версия 11:00, 7 января 2025

Задача зарезервирована: илья52 19:05, 22 декабря 2024 (UTC)

== Вопрос: Q52-e5724f ==

Какой из следующих алгоритмов сортировки имеет время выполнения, НАИМЕНЕЕ зависящее от первоначального порядка ввода?

Ответы

  • Сортировка вставками
  • Быстрая сортировка
  • Правильный ответ: Сортировка слиянием
  • Сортировка выбором
  • Сортировка Шелла

Объяснение

Исходники — вопрос 52 на 39 странице книги «2001-gre-vs-practice.pdf»

Сортировка вставками: В лучшем случае, когда данные уже отсортированы, имеет время выполнения . В худшем случае (когда данные отсортированы в обратном порядке) — O(n²).

Быстрая сортировка: В среднем случае имеет время выполнения O(n log n), но в худшем случае (если выбор опорного элемента неудачен) — O(n²). Однако, в лучшем случае также может быть O(n log n).

3. Merge sort (Сортировка слиянием): Всегда имеет время выполнения O(n log n), независимо от первоначального порядка данных.

4. Selection sort (Сортировка выбором): Всегда имеет время выполнения O(n²), независимо от порядка данных.

5. Shellsort: Время выполнения зависит от выбранной последовательности шагов, но в среднем может достигать O(n log n). В худшем случае может быть O(n^(3/2)) или даже O(n²) в зависимости от реализации.

Таким образом, алгоритм с наименьшим временем выполнения, зависимым от первоначального порядка ввода, — это Merge sort, так как его время выполнения всегда составляет O(n log n).