Форум программистов, компьютерный форум, киберфорум
C++/CLI Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 23.11.2017
Сообщений: 7

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

10.12.2019, 19:24. Показов 1284. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Надо сделать пирамидальную сортировку+ пирамида ( дерево).
Сделал пока только сортировку. Использовал 2 текстбокса и 1 кнопку. В первый вводим массив, во втором нам выводится отсортированный массив.
Проблема в том, что не считает больше 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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
    private: System::Void button1_Click(System::Object^  sender, System::EventArgs^  e) {
                 array<int>^ a = Array::ConvertAll(textBox1->Text->Split(gcnew 
            array<Char>{' '}, StringSplitOptions::RemoveEmptyEntries), gcnew Converter<String^, int>(&Convert::ToInt32));
        int n = a->Length;
 
int sh = 0; 
int temp;
bool b = false; 
for(; ; ) 
{ 
b = false; 
for ( int i = 0; i < n; i++ ) 
{ 
if( i * 2 + 2 + sh < n ) 
{ 
if( ( a[i + sh] >  a[i * 2 + 1 + sh] ) || ( a[i + sh] >  a[i * 2 + 2 + sh] ) ) 
{ 
if ( a[i * 2 + 1 + sh] <  a[i * 2 + 2 + sh] ) 
{ 
temp=a[i+sh]; 
a[i+sh]=a[i*2+1+sh]; 
a[i*2+1+sh]=temp; 
b = true; 
} 
else if ( a[i * 2 + 2 + sh] <  a[ i * 2 + 1 + sh]) 
{ 
temp=a[i+sh]; 
a[i+sh]=a[i*2+1+sh]; 
a[i*2+1+sh]=temp;
b = true; 
} 
} 
 
if( a[i*2 + 2 + sh] <  a[i*2 + 1 + sh] ) 
{ 
temp=a[i+sh]; 
a[i+sh]=a[i*2+1+sh]; 
a[i*2+1+sh]=temp;
b = true; 
} 
} 
else if( i * 2 + 1 + sh < n ) 
{ 
if( a[i + sh] >  a[ i * 2 + 1 + sh] ) 
{ 
temp=a[i+sh]; 
a[i+sh]=a[i*2+1+sh]; 
a[i*2+1+sh]=temp; 
b = true; 
} 
} 
} 
if (!b) 
{ 
sh++; 
} 
if (sh+2==n) 
{ 
break; 
}
} 
textBox2->Text = "";
for ( int i = 0; i < n; i++)
{
    textBox2->Text+=a[i].ToString()+" ";
}
             }
    };
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.12.2019, 19:24
Ответы с готовыми решениями:

Пирамидальная сортировка: исправить код
Закинул код в формс, но не сортирует введенный массив. На форме 2 текстбокса и 1 баттон. В чем проблема, не знаю. Кто, чем, помогите) ...

Сортировка Шелла и пирамидальная сортировка для символов
Здраствуйте, можете пожалуйста привести пример сортировок шелла и пиромидальной сортировки для символов, а то ничего не могу ...

2 сортировки: пирамидальная сортировка и сортировка слиянием
Реализовать два улучшенных алгоритма сортировки. Для каждого алгоритма вычислить показатель качества сортировки (количество операций, т.е....

1
0 / 0 / 0
Регистрация: 23.11.2017
Сообщений: 7
11.12.2019, 22:21  [ТС]
Нашел в чем был не прав. Если мы вводим цифры уже по порядку, то все отлично работает. Принимает любые числа, хоть миллионы и т.д. Но, это же сортировка, в чем смысл вводить числа по порядку. Не могу найти где в коде ошибочка...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.12.2019, 22:21
Помогаю со студенческими работами здесь

Пирамидальная сортировка
можете, кинуть любую программу рабочую Пирамидальная сортировка. PAS с выводом

Пирамидальная сортировка
Помогите: &quot;Разработать программу, обеспечивающую сортировки входного файла методом Пирамиды с подсчетом количества сравнений и...

Пирамидальная сортировка
Вопрос на миллион! Нужно создать пирамидальную сортировку как метод класса. Только на сколько я поняла ,сама пирамидальная сортировка...

Пирамидальная сортировка
Каким будет порядок элементов списка после применения к нему этапа построения пирамиды? Поделитесь опытом, желанно парочку комментарий...

Пирамидальная сортировка
Вот код: #include&lt;iostream&gt; #include &lt;cstdlib&gt; #include&lt;fstream&gt; #include&lt;string&gt; #include&lt;vector&gt; #include&lt;iomanip&gt; using...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru