Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
2 / 1 / 1
Регистрация: 02.11.2021
Сообщений: 178

Пирамидальная сортировка

28.11.2022, 16:30. Показов 646. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уже сутки ломаю голову над этим методом) Может, кто-нибудь заметит, что я не так сделал
Код:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
private static void Swap(ref T x, ref T y)
        {
            T a = x;
            x = y;
            y = a;
        }
        private static char ReplaceChild(T[] arr, int parent)
        {
            int last = arr.Length - 1, left = parent * 2 + 1, right = parent * 2 + 2;
            if (right > last)
            {
                if (left > last)
                {
                    return 'N';
                }
                if (arr[left].CompareTo(arr[parent]) > 0)
                {
                    Swap(ref arr[left], ref arr[parent]);
                    return 'L';
                }
                return 'N';
            }
            if (arr[right].CompareTo(arr[parent]) > 0 && arr[right].CompareTo(arr[left]) >= 0)
            {
                Swap(ref arr[right], ref arr[parent]);
                return 'R';
            }
            if (arr[left].CompareTo(arr[parent]) > 0 && arr[left].CompareTo(arr[right]) >= 0)
            {
                Swap(ref arr[left], ref arr[parent]);
                return 'L';
            }
            return 'N';
        }
        private static void Heapify(T[] arr)
        {
            for (int i = arr.Length / 2; i >= 0; i--)
            {
                char child = ReplaceChild(arr, i);
                while (child != 'N')
                {
                    child = ReplaceChild(arr, child == 'L' ? i * 2 + 1 : i * 2 + 2);
                }
            }
        }
        public static void HeapSort(T[] arr)
        {
            int size = arr.Length;
            for(int i = 0; i < size; i++)
            {
                Heapify(arr[..(size - i - 1)]);
                Swap(ref arr[0], ref arr[size - i - 1]);
            }
        }
Теперь по каждому методу:
Swap-обменивает два элемента
Replace Child-имеет 3 вида возврата: 'N'-обмена не было, 'L'-обмен с левым ребёнком,'R'-обмен с правым ребёнком. Это нужно для того, чтобы затем выполнить дополнительные обмены. Этот метод принимает на вход индекс родителя. Если у него нет детей, возвращает 'N'. Иначе, если какой-то из детей больше, то обменивает их и возвращает 'L' или 'R'
Heapify-начинает обмены с середины массива. В переменную child заносится результат обмена. Если обмена не было, переходит дальше, если был, то соответствующий ребёнок принимается за родителя и снова запускается обмен, пока метод не вернёт 'N'
HeapSort- строит пирамиду и в ней обменивает первый и последний(последний из "активных элементов", которые ещё не отсортированы) элементы. И до тех пор, пока элементы есть
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.11.2022, 16:30
Ответы с готовыми решениями:

Пирамидальная сортировка на С# по алгоритму
Алгоритм сортировки: 1. Пока n&gt;1 2.a0 меняется местами с аn-1 3.n-- 4.протаскиваем а0 через пирамиду Алгоритм построения...

Пирамидальная сортировка (без рекурсии)
Помогите пожалуйста. Нужно сделать пирамидальную сортировку без рекурсии. В обычном коде рекурсия хвостовая , ее нужно заменить на цикл.

Heapsort (метод кучи, пирамидальная сортировка) для строк
Доброго всем времени суток, может ли кто-то поделиться опытом сортировки по алфавиту методом heapsort? Есть массив array с названиями,...

3
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3383 / 2697 / 573
Регистрация: 04.09.2018
Сообщений: 8,506
Записей в блоге: 3
28.11.2022, 17:48
Цитата Сообщение от 54gaT Посмотреть сообщение
'N'-обмена не было, 'L'-обмен с левым ребёнком,'R'-обмен с правым ребёнком
А зачем это? Для визуализации?
0
2 / 1 / 1
Регистрация: 02.11.2021
Сообщений: 178
28.11.2022, 17:59  [ТС]
Да, именно так
0
2 / 1 / 1
Регистрация: 02.11.2021
Сообщений: 178
29.11.2022, 09:43  [ТС]
Была проблема со ссылками, по ходу, потому что метод Heapify не изменял подмассив. Я просто создал список вместо массива и обрезАл его с конца вместо того, чтобы работать с подмассивом. И всё заработало. Странно, что никто не понял этого)))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.11.2022, 09:43
Помогаю со студенческими работами здесь

Сортировка выбором, сортировка вставкой, сортировка заменой, сортировка обменом ("пузырьковая" сортировка)
Создать класс, содержащий массив и реализующий алгоритмы сортировки и бинарного поиска в этом массиве. Класс описать с помощью...

Сравнение алгоритмов сортировки в winforms (турнирная и пирамидальная)
Надо сделать форму в которой в textbox будет вводиться размер массива, потом нажимаешь на кнопку генерируется массив (который выводиться...

Сортировка пузырьком и пирамидальная сортировка заданного массива + бинарный поиск
Заполнить случайным образом одномерный массив размера N и выполнить сортировку пузырьком и пирамидальную сортировку заданного массива. В...

Сортировки во внутренней памяти(сортировка стопками, быстрая и пирамидальная сортировка)
Поясните, пожалуйста на простом языке :) Структура данных содержит записи фиксированного размера (200 байт). Одно из полей записи...

Пирамидальная сортировка. Сортировка кучей, Heap Sort O(n + k log k)
Здравствуйте, у меня есть отсортированный по возрастанию массив с n числами в котором неизвестных k чисел увеличивают на несколько...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru