Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/17: Рейтинг темы: голосов - 17, средняя оценка - 4.53
5 / 5 / 1
Регистрация: 04.11.2009
Сообщений: 66

Сортировка массива

12.03.2010, 13:26. Показов 3497. Ответов 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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
#include <math.h>
#include "Laboratornaya6.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
 int i,n; float x[15];
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::FormActivate(TObject *Sender)
{
Edit1->SetFocus();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
try
{n=StrToInt(Edit1->Text);
x[0]=StrToFloat(Edit2->Text);
x[1]=StrToFloat(Edit3->Text);
}
catch(EConvertError&e)
{ShowMessage("Выввели ошибочное число, повторить ввод");
}
if ((Edit1->Text.Length() == 0) ||
(Edit2->Text.Length() == 0) ||
(Edit3->Text.Length() == 0) )
{MessageDlg("Надо заполнить все поля",
mtInformation, TMsgDlgButtons() << mbOK, 0); return;}
for(i=2;i<n;i++)//формирование массива
x[i]=2*sin(x[i-1]*pow(10,3)/(2*x[i-2]+x[i-1]));
for(i=0;i<n;i++)//вывод массива
Memo1->Lines->Add("x["+IntToStr(i)+"]="+FloatToStrF(x[i],ffFixed,5,2)+"");
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button2Click(TObject *Sender)
{ float summ=0.0,proiz=1; int max,min;
if(CheckBox1->Checked==True)
{for(i=0;i<n;i++)
{summ+=x[i];}
Edit4->Text=FloatToStrF(summ,ffFixed,5,2);
}
 
if(CheckBox2->Checked==True)
{for(i=max=0;i<n;i++){
if(x[i]>x[max])max=i;}
Edit5->Text=FloatToStrF(x[max],ffFixed,5,2);
}
if(CheckBox3->Checked==True)
{for(i=min=0;i<n;i++)
{if(x[i]<x[min]) min=i;}
Edit6->Text=FloatToStrF(x[min],ffFixed,5,2);
}
if(CheckBox4->Checked==True)
{for(i=0;i<n;i++)
{proiz*=x[i];}
Edit7->Text=FloatToStrF(proiz,ffFixed,5,2);
}
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button3Click(TObject *Sender)
{
Edit1->Clear(); Edit2->Clear(); Edit3->Clear();
Edit4->Clear(); Edit5->Clear(); Edit6->Clear(); Edit7->Clear();
Memo1->Clear();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button4Click(TObject *Sender)
{
 Form1->Close();
}
//---------------------------------------------------------------------------
Как отсортировать массив методом выбора и методом пузырька?

Добавлено через 11 минут
C++
1
2
3
4
5
6
7
8
9
10
11
void __fastcall TForm1::Button5Click(TObject *Sender)
{int m,j,buf,I,k;
for(i=0;i<n;i++)
{m=I;
for(j=I;j<n;j++)
if(x[j]>x[m]) m=j;
buf=x[i];
x[i]=x[m];x[m]=buf;
for(k=0;k<n;k++)
Memo1->Lines->Add("x["+IntToStr(k)+"]="+FloatToStrF(x[k],ffFixed,5,2)+"");
}
Вот я пробовал так,но что то не получилось. Подскажите что исправить.
Я знаю что нужно найти сначала максимальный элемент и поменять с первым местами потом повторить этот алгоритм начиная со второго элемента и поменять со вторым .Но что то не получается.Буду благодарен если напишите код или хотя бы поможете.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.03.2010, 13:26
Ответы с готовыми решениями:

Сортировка массива
Столкнулся с проблемой при сортировке одномерного массива &quot;пузырьком&quot; Собсна, код: ...

Сортировка массива
Помогите сделать программу: Массив, нужно отсортировать методом Min и Max, и что бы стрелочками показывалось как элементы меняются...

Сортировка массива
Помогите, пожалуйста! Вот код программы: #include &lt;vcl.h&gt; #include &lt;iostream.h&gt; #include &lt;conio.h&gt; #include...

1
 Аватар для Zerkalka
38 / 37 / 8
Регистрация: 09.03.2010
Сообщений: 79
12.03.2010, 14:25
Попробуй это...
[ссылки удалены]

Добавлено через 46 минут
Сортировка методом пузырька:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
...
void Swap(int arr[], int pos1, int pos2)
{
  int tmp;
  tmp = arr[pos1];
  arr[pos1] = arr[pos2];
  arr[pos2] = tmp;
}
void BubbleSort(int arr[])
{
  int i, j;
  for(i = 0; i < MAX - 1; ++i)
    for(j = 0; j < MAX - i; ++j)
      if (arr[j] > arr[j + 1])
        Swap(arr, j , j + 1);
}
...
Сортировка методом выбора:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
...
void select (int *x, int n)
{
  int i, j, k, exchange;
  int temp;
  for (i=0; i<n-1; i++)
  { exchange =0; //нет перестановок
     k = i ; //номер наименьшего
     temp = x [ i ]; //значение наименьшего
     for ( j = i +1; j < n ; j ++)
       if (x[j] < temp)
       {
         k = j ; temp = x [ j ];//номер и значение наименьшего среди
         exchange=1; //перестановка нужна
       }
     if (exchange)
     {
       x[k]=x[i]; x[i]=temp;
      }
  }
} 
...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.03.2010, 14:25
Помогаю со студенческими работами здесь

Сортировка массива
Привет!! У меня такой вопрос. У меня есть одномерный массив из 7 элементов, мне нужно сделать сортировку значений этих элементов во ...

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

Сортировка массива!
Написал программу, но она не сортирует массив по возрастанию! не могу понять почему?!?! сама программа вычисляет количество элементов...

Сортировка массива структур
Доброе время суток. Есть такая проблема: Существует массив структур zap zapis, cама структура struct zap { ...

Сортировка массива по убыванию
Здравствуйте. Есть код, благодаря которому сортируется массив по убыванию. А мне нужен по возрастанию. Что в коде нужно поменять? c, r...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Блокировка документа от изменений, если он открыт у другого пользователя
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. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru