Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
Kate01
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
#1

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

04.01.2009, 13:45. Просмотров 1273. Ответов 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();      }}
И вот с момента упорядочивания у меня видимо одни ошибки,а как исправить-не знаю, специалисты,помогите пожалуйста...
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
04.01.2009, 13:45     Упорядочить массив в порядке возрастания его элементов
Посмотрите здесь:

Упорядочить массив А в порядке возрастания его элементов C++
C++ Дан массив из n элементов упорядочить его в порядке возрастания
C++ Упорядочить столбцы матрицы в порядке возрастания количества положительных элементов
Содержит ли массив группы элементов, расположенные в порядке возрастания их значений? C++
Упорядочить строки матрицы в порядке возрастания элементов главной диагонали C++
Задан массив, содержащий N элементов. Упорядочить его элементы в порядке возрастания. C++
Структуры. Дан массив записей, содержащих дату и время. Упорядочить этот массив в порядке «возрастания» C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
04.01.2009, 16:24     Упорядочить массив в порядке возрастания его элементов #2
Да действительно, ошибок там "море".
Во-первых, результатом перемножения одномерных массивов будет просто число, поэтому нет необходимости объявлять переменную 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;
}
Kate01
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
07.01.2009, 22:59  [ТС]     Упорядочить массив в порядке возрастания его элементов #3
Цитата Сообщение от manfeese Посмотреть сообщение
Чем перечислять ошибки, лучше скину откорректированный текст...
Спасибо большое!)
А вот мне эту же программу ещё надо переделать через функции.....это как?
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
07.01.2009, 23:36     Упорядочить массив в порядке возрастания его элементов #4
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Может вот так!?..

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)
написать большую - А
Kate01
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
08.01.2009, 12:51  [ТС]     Упорядочить массив в порядке возрастания его элементов #5
Цитата Сообщение от manfeese Посмотреть сообщение
Может вот так!?..
Это вот так через функции?...
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
08.01.2009, 12:54     Упорядочить массив в порядке возрастания его элементов #6
Именно! выделяешь завершенный участок кода и переписываешь его как функцию, чтобы была возможность многократного обращения к этому коду
Kate01
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
08.01.2009, 18:27  [ТС]     Упорядочить массив в порядке возрастания его элементов #7
manfeese
у меня компилятор на эту строчку
C++
1
void Sort(float A[],bool up)
пишет такую ошибку:
Error 6-1.CPP 18: ) expected
как исправить??
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
08.01.2009, 18:32     Упорядочить массив в порядке возрастания его элементов #8
Каким компилятором пользуешся?
Kate01
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
08.01.2009, 18:48  [ТС]     Упорядочить массив в порядке возрастания его элементов #9
э, не знаю тут какой-то в b. c++ v3.1
ISergey
Maniac
Эксперт С++
1347 / 880 / 52
Регистрация: 02.01.2009
Сообщений: 2,645
Записей в блоге: 1
08.01.2009, 19:49     Упорядочить массив в порядке возрастания его элементов #10
у меня компилятор на эту строчку
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" исползовать
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
08.01.2009, 20:14     Упорядочить массив в порядке возрастания его элементов #11
Цитата Сообщение от ISergey Посмотреть сообщение
ML+=A[j]*B[j];//может вместо "j" лучше "i" исползовать
Да, конечно! так будет правильней!!!
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.01.2009, 00:01     Упорядочить массив в порядке возрастания его элементов
Еще ссылки по теме:

C++ Массив: отсортировать массив в порядке возрастания и найти количество соседних пар элементов отличающихся между собой
C++ Упорядочить массив в порядке возрастания.
Упорядочить первые n элементов данного ряда в порядке возрастания (Pascal -> С++) C++
Упорядочить элементы матрицы в порядке возрастания первых элементов C++
C++ Упорядочить массив в порядке возрастания суммы цифр

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

Или воспользуйтесь поиском по форуму:
Kate01
0 / 0 / 0
Регистрация: 04.01.2009
Сообщений: 6
14.01.2009, 00:01  [ТС]     Упорядочить массив в порядке возрастания его элементов #12
вот ещё вопрос, а в блок-схеме что-нибудь менять надо??
Yandex
Объявления
14.01.2009, 00:01     Упорядочить массив в порядке возрастания его элементов
Ответ Создать тему
Опции темы

Текущее время: 15:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru