0 / 0 / 0
Регистрация: 23.11.2017
Сообщений: 7

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

10.12.2019, 19:24. Показов 1288. Ответов 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 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru