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

Heap Sort с рекурсией

26.09.2013, 17:16. Показов 1491. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, в универе задали реализовать пирамидальную сортировку с рекурсией. Нагуглила единственный похожий на правду пример (он был на С++). Попыталась перевести в С#. Код мне понятен, но с синтаксисом Шарпа проблемы.
Вот что вышло:
Кликните здесь для просмотра всего текста
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
namespace piramida
{
    class Program
    {
        static void Main(string[] args)
        { }
        private void heapsort(int[] a, int n)
            {
            // Находим первый элемент, с которого и начнем построение дерева
            //обычно последний в куче
 
            int templog = (int)Math.Pow(2,(Math.Ceiling(Math.Log((float)n))-1)) - 1;
 
            for(int i = templog ;i >= 0 ; i--)
            {
            heapify(a, int i, int n);
            }
 
            //Просеиваем
 
            int temp_n = n;
            while(temp_n>0)
            {
            swap(a, 0, temp_n);
            temp_n--;
            heapify(a, 0, temp_n);
            }
 
            }
 
 
        private void heapify(int[] a, int v, int n)
        {
            //Для элемента a узла v, детьми будут 2*v+1 и 2*v+2 
 
            //Для узлов, у которых нет детей
 
            if (2 * v + 1 >= n)
                return;
 
            //Для узлов, где есть левый ребенок, но нет правого
 
            else if (2 * v + 2 >= n)
            {
                if (a[2 * v + 1] > a[v]) //если левый больше родителя
                {
                    swap(a, v, 2 * v + 1);
                    heapify(a, 2 * v + 1);
                }
            }
 
            //Если есть оба ребенка (и левый, и правый)
 
            else
            {
                //Есть левый больше, чем родитель и правый
 
                if ((a[2 * v + 1] > a[v]) && (a[2 * v + 1] > a[2 * v + 2]))
                {
                    swap(a, v, 2 * v + 1);
                    heapify(a, 2 * v + 1);
                }
 
                //Если правый больше, чем родитель и левый
 
                else if ((a[2 * v + 2] > a[v]) && (a[2 * v + 2] > a[2 * v + 1]))
                {
                    swap(a, v, 2 * v + 2);
                    heapify(a, 2 * v + 1);
                }
            }
 
        }
 
        private void swap(int[] a, int left, int right)
        {
            int temp = a[left];
            a[left] = a[right];
            a[right] = temp;
        }
    }
}


ругается на
C#
1
2
3
4
for(int i = templog ;i >= 0 ; i--)
            {
            heapify(a, int i, int n);
            }
В коде С++ третий аргумент n вообще не прописан. Но, видимо, в Шарпе нужно задавать все три. Уже пробовала вписывать рандомную чушь на "авось сработает". Но не настолько глубоко изучала программирование, чтобы понять суть ошибки. Прошу Вас о помощи)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.09.2013, 17:16
Ответы с готовыми решениями:

Public variable in heap sort
Проблема такая. Нужно отсортировать массив, введенный пользователем. Я написала код хипсортинга, с функциями heapify, build heap, heapsort....

Сортировка массива методом Heap Sort
Не выходит отсортировать массив в txt, методом Heap Sort. Download Project using System; using System.Collections.Generic; using...

Хранение переменных в HEAP (устройство Stack и Heap)
Добрый день. Проблемы с устройством памяти стека и кучи: если я создаю объект vanya класса Person, с приватными переменными int age, high,...

1
484 / 439 / 123
Регистрация: 05.01.2010
Сообщений: 1,848
26.09.2013, 17:44
Цитата Сообщение от MayWal Посмотреть сообщение
Здравствуйте, в универе задали реализовать пирамидальную сортировку с рекурсией. Нагуглила единственный похожий на правду пример (он был на С++). Попыталась перевести в С#. Код мне понятен, но с синтаксисом Шарпа проблемы.
Вот что вышло:
Кликните здесь для просмотра всего текста
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
namespace piramida
{
    class Program
    {
        static void Main(string[] args)
        { }
        private void heapsort(int[] a, int n)
            {
            // Находим первый элемент, с которого и начнем построение дерева
            //обычно последний в куче
 
            int templog = (int)Math.Pow(2,(Math.Ceiling(Math.Log((float)n))-1)) - 1;
 
            for(int i = templog ;i >= 0 ; i--)
            {
            heapify(a, int i, int n);
            }
 
            //Просеиваем
 
            int temp_n = n;
            while(temp_n>0)
            {
            swap(a, 0, temp_n);
            temp_n--;
            heapify(a, 0, temp_n);
            }
 
            }
 
 
        private void heapify(int[] a, int v, int n)
        {
            //Для элемента a узла v, детьми будут 2*v+1 и 2*v+2 
 
            //Для узлов, у которых нет детей
 
            if (2 * v + 1 >= n)
                return;
 
            //Для узлов, где есть левый ребенок, но нет правого
 
            else if (2 * v + 2 >= n)
            {
                if (a[2 * v + 1] > a[v]) //если левый больше родителя
                {
                    swap(a, v, 2 * v + 1);
                    heapify(a, 2 * v + 1);
                }
            }
 
            //Если есть оба ребенка (и левый, и правый)
 
            else
            {
                //Есть левый больше, чем родитель и правый
 
                if ((a[2 * v + 1] > a[v]) && (a[2 * v + 1] > a[2 * v + 2]))
                {
                    swap(a, v, 2 * v + 1);
                    heapify(a, 2 * v + 1);
                }
 
                //Если правый больше, чем родитель и левый
 
                else if ((a[2 * v + 2] > a[v]) && (a[2 * v + 2] > a[2 * v + 1]))
                {
                    swap(a, v, 2 * v + 2);
                    heapify(a, 2 * v + 1);
                }
            }
 
        }
 
        private void swap(int[] a, int left, int right)
        {
            int temp = a[left];
            a[left] = a[right];
            a[right] = temp;
        }
    }
}


ругается на
C#
1
2
3
4
for(int i = templog ;i >= 0 ; i--)
            {
            heapify(a, int i, int n);
            }
В коде С++ третий аргумент n вообще не прописан.
Строка 7
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.09.2013, 17:44
Помогаю со студенческими работами здесь

Ошибка 500 в менеджере модулей Joomla - Out of sort memory, consider increasing server sort buffer size
Привет! Подскажите что делать , когда такая проблема ?

Sort(), третий параметр: как sort() выбирает аргументы из переданной последовательности для переданной функции?
Вот sotr() 2 параметра - итераторы, а третий функцию. Допустим, моя функция сортирует список по возрастанию сумм цифр числа. Как sort()...

Heap in C++
Как подключить кучу в C++?

Heap in C++
Можно ли сделать кучу (make_heap) не максимальную, а минимальную?

Heap overflows
Всем привет! Помогите пожалуйста с таким вопросом. Я написала так : //digits = X.digits; то есть два указателя ссылаются на один и то...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru