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

Упорядочить массив в порядке возрастания его элементов

04.01.2009, 13:45. Показов 2109. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот условие задания:
-ввести массив А6,сформулировать В6 по формуле:Вi=sinAi
-упорядочить массив А в порядке возрастания его элементов(массив А1),а В-в порядке убывания(массив В1).
-найти произведения ML=А*В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
#include <stdio.h>
#include <conio.h>
#include <math.h>
#define n 6
void main ()
{    
    float A[n],B[n],ML[n],r;
    int i,j,k,im;
//    clrscr();
 
    printf("massive A[%i]:\n",n);
    for(i=0;i<n;i++)
{       scanf("%f",&A[i]);
 
 }
    
    for(i=0;i<n;i++)
{       B[i]=sin(A[i]);
    printf("%f\n",B[i]); }
 
for(j=0; j<n;j++)  {
    im=j;    
    for(i=j+1;i<n;i--)
 
    if(A[j]<A[im])
    im=i;
    if(im!=j)
    {r=A[j];
    A[j]=A[im];
    A[im]=r; }}
    for(i=j+1;i<n;i++)
{    im=j;
    for(i=j-1;i<n;i--) 
    if(B[i]<B[im])
{    im=i;
    if(im!=j)
    {r=B[j];
    B[j]=B[im];
    B[im]=r; }}
    for(i=0;j<n;j++)
    for(k=0;k<n;k++)
        {{
    ML[i]=ML[j]+A[k]*B[k*j]; printf("%ML ",ML[i]);
        printf("% f ",ML[i]); }}
 
    
    getch();      }}
И вот с момента упорядочивания у меня видимо одни ошибки,а как исправить-не знаю, специалисты,помогите пожалуйста...
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.01.2009, 13:45
Ответы с готовыми решениями:

Упорядочить массив А в порядке возрастания его элементов
Вот программа на С++ #include &lt;stdio.h&gt; #include &lt;math.h&gt; #include &lt;conio.h&gt; #define n 6 void main () {float A;B;A;B;B; int...

Дан массив из n элементов упорядочить его в порядке возрастания
Привет.Помогите пожалуйста решить задачу. Заранее спасибо. Дан массив из n элементов упорядочить его в порядке возрастания. (если...

Задан массив, содержащий N элементов. Упорядочить его элементы в порядке возрастания.
Буду очень признателен, если поможете безрукому... 6. Задан массив, содержащий N элементов. Упорядочить его элементы в порядке...

11
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
04.01.2009, 16:24
Да действительно, ошибок там "море".
Во-первых, результатом перемножения одномерных массивов будет просто число, поэтому нет необходимости объявлять переменную ML как массив.
Во-вторых, циклы некорректно сформированы.
Чем перечислять ошибки, лучше скину откорректированный текст...
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
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop
#include <stdio.h>
#include <math.h>
//---------------------------------------------------------------------------
    const int n = 6;
 
    float A[n],B[n];
    float r = 0, ML = 0;
    int i,j;
 
#pragma argsused
int main(int argc, char* argv[])
{
    printf("massive A[%i]:\n",n);
 
    for(i=0;i<n;i++)
        {
          scanf("%f",&A[i]);
        }
 
    printf("\n");
 
    for(i=0;i<n;i++)
        {
         B[i]=sin(A[i]);
         printf("%f\n",B[i]);
        }
 
    for(i=0; i<n;i++)
      {
        for(j=0;j<n-1-i;j++)
          {
            if(A[j]>A[j+1])
              {
                r=A[j];
                A[j]=A[j+1];
                A[j+1]=r;
              }
          }
      }
 
    for(i=0; i<n;i++)
      {
        for(j=0;j<n-1-i;j++)
          {
            if(B[j]>B[j+1])
              {
                r=B[j];
                B[j]=B[j+1];
                B[j+1]=r;
              }
          }
      }
 
    for(i=0;i<n;i++)
        ML+=A[j]*B[j];
 
    printf("\nML = %.2f",ML);
 
    return 0;
}
0
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
07.01.2009, 22:59  [ТС]
Цитата Сообщение от manfeese Посмотреть сообщение
Чем перечислять ошибки, лучше скину откорректированный текст...
Спасибо большое!)
А вот мне эту же программу ещё надо переделать через функции.....это как?
0
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
07.01.2009, 23:36
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Может вот так!?..

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
#include <conio.h>
#include <stdio.h>
#include <math.h>
//---------------------------------------------------------------------------
    const int n = 6;
 
    float A[n],B[n];
    float r = 0, ML = 0;
    int i,j;
 
void GetMatrix()
{
    for(i=0;i<n;i++)
        scanf("%f",&A[i]);
    printf("\n");
}
 
void Sort(float a[],bool up)
{
    for(i=0; i<n;i++)
      {
        for(j=0;j<n-1-i;j++)
          {
          if (up)
          {
            if(A[j]>A[j+1])
              {
                r=A[j];
                A[j]=A[j+1];
                A[j+1]=r;
              }
          }
          else
            if(A[j]<A[j+1])
              {
                r=A[j];
                A[j]=A[j+1];
                A[j+1]=r;
              }
          }
      }
}
 
int main()
{
    printf("massive A[%i]:\n",n);
 
    GetMatrix();
 
    for(i=0;i<n;i++)
        {
         B[i]=sin(A[i]);
         printf("%f\n",B[i]);
        }
 
    Sort(A,true);
    Sort(B,false);
 
    for(i=0;i<n;i++)
        ML+=A[j]*B[j];
 
    printf("\nML = %.2f",ML);
 
    getch();
    return 0;
}
Добавлено через 10 минут 1 секунду
Плохо написал!!! В процедуре Sort надо все большие буквы А поменять на маленькие.

Добавлено через 49 секунд
Либо в самом заголовке
C++
1
void Sort(float a[],bool up)
написать большую - А
0
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
08.01.2009, 12:51  [ТС]
Цитата Сообщение от manfeese Посмотреть сообщение
Может вот так!?..
Это вот так через функции?...
0
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
08.01.2009, 12:54
Именно! выделяешь завершенный участок кода и переписываешь его как функцию, чтобы была возможность многократного обращения к этому коду
0
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
08.01.2009, 18:27  [ТС]
manfeese
у меня компилятор на эту строчку
C++
1
void Sort(float A[],bool up)
пишет такую ошибку:
Error 6-1.CPP 18: ) expected
как исправить??
0
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
08.01.2009, 18:32
Каким компилятором пользуешся?
0
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
08.01.2009, 18:48  [ТС]
э, не знаю тут какой-то в b. c++ v3.1
0
Maniac
Эксперт С++
 Аватар для ISergey
1465 / 966 / 160
Регистрация: 02.01.2009
Сообщений: 2,820
Записей в блоге: 1
08.01.2009, 19:49
у меня компилятор на эту строчку
C++
1
void Sort(float A[],bool up)
пишет такую ошибку:
Error 6-1.CPP 18: ) expected
как исправить??
так наверно лучше будет
C++
1
void Sort(float *A,bool up)
Добавлено через 12 минут 5 секунд
у вас здесь ошибка
C++
1
2
for(i=0;i<n;i++) 
   ML+=A[j]*B[j];//может вместо "j" лучше "i" исползовать
1
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
08.01.2009, 20:14
Цитата Сообщение от ISergey Посмотреть сообщение
ML+=A[j]*B[j];//может вместо "j" лучше "i" исползовать
Да, конечно! так будет правильней!!!
0
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
14.01.2009, 00:01  [ТС]
вот ещё вопрос, а в блок-схеме что-нибудь менять надо??
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.01.2009, 00:01
Помогаю со студенческими работами здесь

Упорядочить первые 10 элементов в порядке возрастания, а другие в порядке убывания
сформировать случайным образом массив из 20 элементов. Упорядочить первые 10 в порядке возрастания, а другие в порядке убывания. кто знает...

Упорядочить массив в порядке возрастания.
Народ помогите с задачкой. Задан массив Z(m) целых чисел. Упорядочить массив в порядке возрастания. Удалить из массива два последних...

Построенный массив упорядочить в порядке возрастания
Здравствуйте, уважаемые кодеры. Заданный одномерный массив А из 10 цифр. Построить массив В, каждый элемент которого вычисляется: bі =...

Упорядочить массив в порядке возрастания и убывания
1 Вариант. Заранее спасибо :)

Упорядочить массив в порядке возрастания суммы цифр
Здравствуйте! Помогите пожалуйста дополнить код. Необходимо отсортировать массив в порядке возрастания суммы цифр. Если есть одинаковая...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью 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. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru