Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 17.04.2015
Сообщений: 19

Сортировка пузырьком

22.04.2015, 11:13. Показов 2636. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста, нужен код для сортировки массива пузырьком в StringGrid. Пробовал сделать вот так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int i=StringGrid1->RowCount;
int j=StringGrid1->ColCount;
int array[100];
int col;
int trash=0;
for (int i=1; i<=col ; i++)
    {
 
        for (int j=1; j<=col-i; j++)
        {
 
            if (array [j]>array [j+1])
            {
 
                trash=array[j];
                array [j]=array [j+1];
                array [j+1]=trash;
            }
        }
    }
но ничего не происходит по нажатию кнопки сортировать.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
22.04.2015, 11:13
Ответы с готовыми решениями:

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

Двусвязный список. сортировка пузырьком.
Помогите пожалуйста переделать код из delphi в с++. вот код type //Типы для описания списка. //Тип данных - определяет...

Кривая сортировка пузырьком StringGrid
Есть код сортировки писал сам может что не учел но не могу понять кода жму на кнопку пропадает значения в 1 строке и сортирует другие...

9
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
22.04.2015, 11:42
Непонятны используемые переменные, но если по самому алгоритму сортировки, то цикл по j попробуйте объявить так:
C
1
for (int j=0; j<=col-i-1; j++)
0
return (true);
 Аватар для mimicria
1977 / 1112 / 221
Регистрация: 19.04.2011
Сообщений: 2,346
22.04.2015, 12:11
Цитата Сообщение от BogdanSabatiuk Посмотреть сообщение
ничего не происходит
С таким кодом и не будет ничего происходить. Процитирую комментариями:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int i=StringGrid1->RowCount;
int j=StringGrid1->ColCount;
int array[100]; // Почему 100, а вдруг больше? И вообще, таблица двумерная, а массив одномерный. Что сортировать будем: строки? столбцы? Непонятно...
int col; // Объявили col но не инициализировали
int trash=0;
for (int i=1; i<=col ; i++) // Тут условие <=col, но он не инициализирован, там мусор
    {
 
        for (int j=1; j<=col-i; j++)
        {
 
            if (array [j]>array [j+1]) // сравниваются элементы массива, но в них тоже мусор, ибо не инициализировался массив. Тут должны быть ячейки таблицы, видимо
            {
 
                trash=array[j];
                array [j]=array [j+1];
                array [j+1]=trash;
            }
        }
    }
1
0 / 0 / 0
Регистрация: 17.04.2015
Сообщений: 19
22.04.2015, 18:43  [ТС]
Можете отредактировать код, если не сложно?
0
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
22.04.2015, 23:11
Цитата Сообщение от BogdanSabatiuk Посмотреть сообщение
Можете отредактировать код, если не сложно?
Это не сложно. Это - невозможно.
Ибо непонятно:
1) размерность грида (строки и столбцы)
2) данные непосредственно в ячейках или грид привязан к коллекции
0
0 / 0 / 0
Регистрация: 17.04.2015
Сообщений: 19
23.04.2015, 07:47  [ТС]
1)Размерность задается вручную, т.е зарание она неизвестна.
2) Данные так же вводятся вручную.
0
return (true);
 Аватар для mimicria
1977 / 1112 / 221
Регистрация: 19.04.2011
Сообщений: 2,346
23.04.2015, 08:08
Цитата Сообщение от BogdanSabatiuk Посмотреть сообщение
1)Размерность задается вручную, т.е зарание она неизвестна.
Определитесь уже что сортировать, столбцы или строки? Таблица двумерная.
1
0 / 0 / 0
Регистрация: 17.04.2015
Сообщений: 19
24.04.2015, 07:22  [ТС]
Переделал программу теперь массив одномерный есть только одна строка и её надо отсортировать.
0
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
24.04.2015, 10:21
если одна строка, то как-то так
C
1
2
3
4
5
6
7
8
9
10
int col=StringGrid1->ColCount;
int trash=0;
for (int i=1; i<=col ; i++)
    for (int j=0; j<=col-i-1; j++)
        if (StrToInt(StringGrid1->Cells[0][j])>StrToInt(StringGrid1->Cells[0][j+1]))
        {
            trash=StrToInt(StringGrid1->Cells[0][j]);
            StringGrid1->Cells[0][j]=StringGrid1->Cells[0][j+1]; //не уверен
            StringGrid1->Cells[0][j+1]=IntToStr(trash);
        }
0
0 / 0 / 0
Регистрация: 17.04.2015
Сообщений: 19
24.04.2015, 15:35  [ТС]
Class EConvertError вылетает

Добавлено через 10 минут
А всё, разобрался. Огромное спасибо за помощь, ребята!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.04.2015, 15:35
Помогаю со студенческими работами здесь

Сортировка файла пузырьком используя StringGrid
//Сортирует только два соседних элемента, а последний не сортируется вообще for (b=0;b&lt;A-&gt;Count-1;b++) { for...

Блок схема.Сортировка «Пузырьком», Сортировка методом «Последовательных перестановок», Сортировка «Вставками»
Помогите, нужны блок схемы Сортировка «Вставками» Program Vstavka; uses dos; Type mass=array of integer; Var i,b,n,j,a:...

Сортировка пузырьком
Всем доброго времени суток. Помогите пожалуйста написать программу сортировки пузырьком в соответствии с данной блок-схемой.

Сортировка пузырьком
вот написала программу но не работает :( #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;ctime&gt; #include &lt;cstdlib&gt; using...

Сортировка пузырьком
Как сделать пошаговый вывод сортировки? #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;ctime&gt; using namespace std; void...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru