|
0 / 0 / 0
Регистрация: 30.11.2022
Сообщений: 4
|
|
Шейкерная сортировка массива30.11.2022, 12:10. Показов 6928. Ответов 14
Метки нет (Все метки)
Здравствуйте, помогите, пожалуйста с решением следующей проблемы:
При сортировке массива с помощью собственной функции swap (по условию задачи дополнительно считается количество сравнений и перестановок) в последний элемент сохраняется мусор: void swap(int* a, int* b) { int temp = *a; *a = *b; *b = temp; } void shaker_sort(int* A, size_t n, struct results* res) { int left = 0; int right = n; int last_swap; res->change_count = 0; res->comp_count = 0; while (left < right) { last_swap = 0; for (int i = left; i < right; i++) { res->comp_count++; if (A[i] > A[i + 1]) { res->change_count++; swap(&A[i], &A[i + 1]); last_swap = i; } } right = last_swap; for (int j = left; j > left; j--) { res->comp_count++; if (A[j] > A[j - 1]) { res->change_count++; swap(&A[j], &A[j - 1]); last_swap = j; } } left = last_swap; } }
0
|
|
| 30.11.2022, 12:10 | |
|
Ответы с готовыми решениями:
14
Шейкерная сортировка массива Шейкерная сортировка массива (в виде функции) Шейкерная сортировка (перемешиванием) |
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|
| 30.11.2022, 13:09 | |
|
Где-то явно границу в цикле надо сделать -1 (минус 1) (мне лень думать где именно)
Вы явно самое большое число (9) сравниваете и обмениваете с мусором за границей массива, чего делать не надо. Кстати, на в результате сортировки единички не вместе идут, тоже странно
0
|
|
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
|||||||
| 30.11.2022, 13:39 | |||||||
Сообщение было отмечено maximsourov как решение
Решениеmaximsourov, У вас несколько ошибок Я насчитал в сумме около пяти!
1
|
|||||||
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
||
| 30.11.2022, 13:54 | ||
0
|
||
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
||
| 30.11.2022, 14:01 | ||
|
Даже с этим вам
0
|
||
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|
| 30.11.2022, 14:05 | |
|
SmallEvil
Чувачок, не занимайся психоанализом, у тебя не получается. Лень, потому что не интересно. Прикинь, оно всё вместе может быть. Прикольно, да?
0
|
|
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
|
| 30.11.2022, 14:42 | |
|
0
|
|
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|
| 30.11.2022, 14:44 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 30.11.2022
Сообщений: 4
|
|
| 01.12.2022, 16:04 [ТС] | |
|
Спасибо Вам огромное! Как видите уровень знания языка, как и опыт программирования в целом, у меня небольшой, а лабораторные в ВУЗе делать заставляют, при этом не давая необходимый материал.
Еще хотел спросить: можно ли в этот алгоритм добавить возможность нахождения количества различных чисел среди элементов массива? Еще раз огромное спасибо.
0
|
|
| 01.12.2022, 16:14 | |
|
0
|
|
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
||
| 01.12.2022, 18:44 | ||
|
Не по теме: ram876, это не лень. Добавлено через 3 минуты После сортировки примените алгоритм std::unqiue или воспользуйтесь для std::set (при этом сортировка уже не нужна)
0
|
||
|
0 / 0 / 0
Регистрация: 30.11.2022
Сообщений: 4
|
|
| 01.12.2022, 19:02 [ТС] | |
|
0
|
|
|
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
|
|||
| 01.12.2022, 19:07 | |||
|
Массив отсортирован - осталось пробежать по нему постедовательно. Если очередной элемент не равен предыдущему - counter++, если равен предыдущему - пропускаем, идем дальше, на следующий элемент. В результате посчитаете количество уникальных элементов. Добавлено через 33 секунды
1
|
|||
|
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
|
|
| 01.12.2022, 19:08 | |
|
1
|
|
|
0 / 0 / 0
Регистрация: 30.11.2022
Сообщений: 4
|
||||
| 01.12.2022, 19:59 [ТС] | ||||
|
Дело в том, что у меня в школе как таковой информатики не было, готовился к ЕГЭ по видео в ютубе, сдавал на python. ЕГЭ то сдал, а суперским программистом не стал пока что. Сейчас смотрю курс по C++ в интернете, и также надо делать лабораторные, но они пока выше моего уровня) Добавлено через 57 секунд Будем разбираться)
0
|
||||
| 01.12.2022, 19:59 | |
|
Помогаю со студенческими работами здесь
15
Шейкерная сортировка + сортировка слиянием Шейкерная сортировка двусвязного списка Шейкерная сортировка без использования while цикла Шейкерная сортировка массива шейкерная сортировка одномерного массива Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет
значение производной при заданном х
Логарифм записывается как: (x-2)log(x^2+2) -. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|