Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 24.06.2013
Сообщений: 3

визуализация сортировки массива

24.06.2013, 07:22. Показов 3416. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Собственно имеется задание: Дан массив чисел из 20 штук. Расставить числа по убыванию.
Использовать графику для визуализации процесса расстановки.

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

Код
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
#include<process.h>
# include <graphics.h>
# include <conio.h>
# include <iostream.h>
# include <stdlib.h>
# include <stdio.h>
void print(int x, int y, char *str)
 {
 gotoxy(x,y);
 cprintf(str);
 }//Рисует на экране наше меню, используя предыдущую функцию
 void menu()
 { print(2,1,"1. Zadanie:");
  print(2,2,"2. ishodnii massiv");
  print(2,3,"3. sortirovannii massiv");
  print(2,4,"4. ochishenie ekrana!");
  print(2,5,"5. exit!");   }
//Рисует планочку. x, y -координаты, color - цвет планочки, tcolor - цвет выделенного текста, str - сам текст
 void block(int x, int y, int color, int tcolor, char *str)
 {  textcolor(tcolor);
    textbackground(color);
    print(x,y,str);   }
void show(int i, int x, int y, int*array)
//подключение  драйвера
{  int dr=DETECT, mod,err,k;
       initgraph(&dr,&mod, " ");
       err=graphresult();
       if(err)
         {  cout<<"error initgraph"<<grapherrormsg(err);
         exit(1);  }
for(i=0;i<20;i++)
{
setcolor(15);
setfillstyle(SOLID_FILL,i+1);
bar(20+30*i, 455-20*array[i], 50+30*i-1, 455);
setfillstyle(SOLID_FILL,i);  }
closegraph();
gotoxy(x,y);
for(i=0;i<20;i++)
print(20,20,"#");
getch();
}
void sort(int a,int i, int j, int*array)
{//   cout<<"\n otsortirovannii massive:\n ";
  for(j=0;j<20;j++)
     { for(i=0;i<19;i++)
      {   if(array[i]< array [i+1])
    {a= array [i];
     array [i]= array [i+1];
     array [i+1]=a;
      }}     }
//    for(i=0;i<20;i++)
//  cout<< array [i]<<" ";
void main()
{
clrscr();
randomize();
int*array;
int i,j,a;
int key; //код нажатой клавиши
int color=15; //цвет планки по умолчанию
int pos; //позиция планки
  cout<<"\n\n ishodnii massive:\n ";
  for(i=0;i<20;i++)
    {
    array [i]=random(20);
    cout<< array [i]<<" ";
    }
        //заполнение массива случайными числами
//строковый массив с названиями строк меню
 char *mas[5]={
 "1. zadanie:",
 "2. ishodnii massiv",
 "3. sortirovannii massiv",
 "4. ochishenie ekrana!",
 "5. exit!"
 };
 //вывели меню
 menu();
//установили планку на первую строку
 block(2,1,color, 4, mas[0]);
//начальная позиция планки = 0
 pos=0;
//Цикл обработки нажатия клавиши - пока не нажмёшь Esc
abc: 
do {
 key=getch(); //Получим код клавиши
//Запомнили этот код
 switch(key) {
//Если была нажата стрелка вниз
 case 80:{
 if (pos<4) //Если пункт не последний
 {
 pos++; //Спускаемся ниже
 block(2, 1+pos-1, 0, 7, mas[pos-1]); //Восстанавливаем предыдущее местоположение в нормальный незакрашенный вид
 block(2, 1+pos, color, 4, mas[pos]); //Закрашиваем планочкой новое место
 }
 else //Если пункт меню последний,
 {
 block(2, 1+pos, 0, 7, mas[pos]); //Восстанавливаем его
 pos=0; //И переходим опять на первый
 block(2, 1+pos, color, 4, mas[pos]); //Закрашиваем его
 }
 break;
 };
 //Если стрелка вверх
 case 72:{ //аналогично стрелке вниз.
 if (pos>0)
 {
 pos--;
 block(2, 1+pos+1, 0, 7, mas[pos+1]);
 block(2, 1+pos, color, 4, mas[pos]);
}
 else {
 block(2, 1+pos, 0, 7, mas[pos]);
 pos=4;
 block(2, 1+pos, color, 4, mas[pos]);
 } //Если Enter
 case 13: {
//Запоминаем на каком пункте она была нажата
 switch(pos){
case 0:
outtextxy(100,30,"sortirovatb massiv iz 20 chisel po ybivaniu.");
case 1:
show();
goto abc;
case 2:
sort();
show();
case 3:
clrscr();
goto abc;
//Если пункт меню был "Выход",
case 4: exit(1); //Выйти из программы
 
 }
 }}while(key!=27); //Пока не нажмёшь Esc
} };
}}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.06.2013, 07:22
Ответы с готовыми решениями:

Визуализация алгоритмов сортировки
Нужно создать программу для визуализации 3 алгоритмов сортировки. Подскажите, как и на чем лучше делать?

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

Пример быстрой сортировки массива строк и сортировки методом выбора
Добрый вечер. Скиньте пожалуйста пример быстрой сортировки массива строк и сортировки массива строк методом выбора. Очень срочно надо,...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.06.2013, 07:22
Помогаю со студенческими работами здесь

Написать две функции сортировки массива целых чисел, реализующих заданные алгоритмы сортировки – один из класса квадрат
#include &lt;stdio.h&gt; #include &quot;stdafx.h&quot; #include &quot;iostream&quot; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; int main() { int sort; ...

Визуализация сортировки массива
Народ необходимо написать программу визуальной сортировки массива. Но возник вопрос как это сделать. Я сначала создаю несколько...

Визуализация сортировки массива пузырьком
Было дано задание, написать визуализацию пузырька. я почти с этим справилась (на самом примитивном уровне), но график перерисовываться не...

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

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


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru