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

решить(массивы)! - C++

Восстановить пароль Регистрация
 
Alexandra555
0 / 0 / 0
Регистрация: 17.05.2011
Сообщений: 33
19.05.2011, 19:16     решить(массивы)! #1
Помогите решить задачки! Очень надо!!

1)Даны вещественные массивы D[5][5], A[5][5]. Для каждого
массива опpеделить сpеднее аpифметическое наибольшего и
наименьшего значений массива.


2)Даны вещественные массивы F[3][8], A[3][8]. Для каждого
массива определить максимальный и минимальный элементы
среди элементов, расположенных в нечетных столбцах.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
oinari
 Аватар для oinari
5 / 5 / 0
Регистрация: 18.10.2009
Сообщений: 69
19.05.2011, 19:19     решить(массивы)! #2
в чем проблемы?
Alexandra555
0 / 0 / 0
Регистрация: 17.05.2011
Сообщений: 33
19.05.2011, 19:27  [ТС]     решить(массивы)! #3
Цитата Сообщение от oinari Посмотреть сообщение
в чем проблемы?
Проблемы с задачками не знаю как решать!
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 20:24     решить(массивы)! #4
Alexandra555, Вот первая

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
#include <iostream.h>
#include <stdio.h>
#include <iostream.h>
#include <conio.h>
#include<stdlib.h>
#include<iomanip.h>
void massiv1()
 {
    float D[5][5];
    int i, j;
            randomize();
            cout<<endl;
            cout<<"----Massiv D----"<<endl;
            for(i=0; i<5; i++) //заполняем значениями
            {
                for(j=0; j<5; j++)
                    {
                        D[i][j]=(random(100)-50)/10.0;
                        cout<<setiosflags(ios::left)<<setw(6)<<D[i][j]; //выравниваем элементы матрицы
                    }
                    cout<<endl;
            }
    
            double Max=D[0][0];
            for(i=0; i<5; i++) // первый этап: находим максимальный элемент
            {
                for(int j=0; j<5; j++)
                {
                    if(D[i][j]>Max)
                    {
                        Max=D[i][j];
                    }
                }
            }
            double Min=D[0][0];
            for(i=0; i<5; i++) // второй этап: находим максимальный элемент
            {
                for(int j=0; j<5; j++)
                {
                    if(D[i][j]<Min)
                    {
                        Min=D[i][j];
                    }
                }
            }
    
            double resultat=Max*Min/2;
            cout<<"*****************"<<endl;
            cout<<"RESULTAT (srednee ar. min i max): "<<resultat;
    return;
}
 
  void massiv2()
{
    float A[5][5];
    int i, j;
            randomize();
            cout<<endl;
            cout<<"----Massiv A----"<<endl;
            for(i=0; i<5; i++) //заполняем значениями
            {
                for(j=0; j<5; j++)
                    {
                        A[i][j]=(random(80)-40)/10.0;
                        cout<<setiosflags(ios::left)<<setw(6)<<A[i][j]; //выравниваем элементы матрицы
                    }
                    cout<<endl;
            }
    
            double Max=A[0][0];
            for(i=0; i<5; i++) // первый этап: находим максимальный элемент
            {
                for(int j=0; j<5; j++)
                {
                    if(A[i][j]>Max)
                    {
                        Max=A[i][j];
                    }
                }
            }
            double Min=A[0][0];
            for(i=0; i<5; i++) // второй этап: находим максимальный элемент
            {
                for(int j=0; j<5; j++)
                {
                    if(A[i][j]<Min)
                    {
                        Min=A[i][j];
                    }
                }
            }
    
            double resultat=Max*Min/2;
            cout<<"*****************"<<endl;
            cout<<"RESULTAT (srednee ar. min i max): "<<resultat;
    return;
}
int main()
{
    massiv1();
    cout<<endl;
    massiv2();
    
    getch();
    return 0;
}
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
19.05.2011, 20:25     решить(массивы)! #5
.Malek., а если бы пять массивов было ?)
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 20:26     решить(массивы)! #6
Ну предложите лучший вариант
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
19.05.2011, 20:33     решить(массивы)! #7
.Malek., просто намного рациональнее объявить массивы в main (), и создать некоторую функцию, которая принимает массив в кач - ве параметра и выполняет с ним необходимые действия. Тем самым, функция у вас будет одна, а массивов - хоть 10.
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 20:36     решить(массивы)! #8
Но дело в то что randomize когда одинаковые 2 матрицы ПО РАЗМЕРАМ он заполняет одинаковыми числами.
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
19.05.2011, 20:54     решить(массивы)! #9
Пользуйтесь более стандартной конструкцией:
C++
1
2
3
srand (time (NULL)); // достаточно написать один раз, инклуд ctime
..
int i = rand () % 10; // инклуд cstdlib
Гамбит
13 / 13 / 1
Регистрация: 19.10.2009
Сообщений: 93
19.05.2011, 21:11     решить(массивы)! #10
Цитата Сообщение от neske Посмотреть сообщение
.Malek., просто намного рациональнее объявить массивы в main (), и создать некоторую функцию, которая принимает массив в кач - ве параметра и выполняет с ним необходимые действия. Тем самым, функция у вас будет одна, а массивов - хоть 10.
соглашусь. Так будет рациональнее.
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 21:19     решить(массивы)! #11
Лучший вариант
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 <iostream.h>
#include <stdio.h>
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <iomanip.h>
#include <time.h>
const int N=5;
const int M=5;
void massiv(double Massiv[N][M])
 {
        int i, j;
        srand (time (NULL));
        
        cout<<"----Massiv---"<<endl;
        for(i=0; i<N; i++) //заполняем значениями
        {
            for(j=0; j<M; j++)
            {
                Massiv[i][j]=(rand ()%50)/10.0;
                cout<<setiosflags(ios::left)<<setw(6)<<Massiv[i][j]; //выравниваем элементы матрицы
            }
            cout<<endl;
        }
        
        double Max=Massiv[0][0];
        for(i=0; i<N; i++) // первый этап: находим максимальный элемент
        {
            for(int j=0; j<M; j++)
            {
                if(Massiv[i][j]>Max)
               {
                    Max=Massiv[i][j];
               }
            }
        }
        double Min=Massiv[0][0];
        for(i=0; i<N; i++) // второй этап: находим максимальный элемент
        {
        for(int j=0; j<M; j++)
        {
            if(Massiv[i][j]<Min)
            {
                Min=Massiv[i][j];
            }
        }
        }
        double resultat=Max*Min/2;
        cout<<"*****************"<<endl;
        cout<<"RESULTAT (srednee ar. min i max): "<<resultat<<endl;
        return;
}
 
  
int main()
{
        double D[N][M];
        double A[N][M];
        massiv(D);
        massiv(A);
        getch();
        return 0;
}
но тут СНОВА два одинаковых массива
Alexandra555
0 / 0 / 0
Регистрация: 17.05.2011
Сообщений: 33
19.05.2011, 21:28  [ТС]     решить(массивы)! #12
.Malek., огромное Вам СПАСИБО!
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 21:35     решить(массивы)! #13
Берите первый вариант там массивы разные
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
19.05.2011, 21:51     решить(массивы)! #14
C++
1
srand (time (NULL))
в main засуньте.


И у вас ошибка в 48 строке еще.
C++
1
double resultat=(Max+Min)/2;
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 21:55     решить(массивы)! #15
Спасибо neske, а почему когда в main оно разные выдает значения а если в функции то одно и тоже самое?
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
#include <iostream.h>
#include <stdio.h>
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <iomanip.h>
#include <time.h>
const int N=5;
const int M=5;
void massiv(double Massiv[N][M])
 {
        int i, j;
        
                
        cout<<"----Massiv---"<<endl;
        for(i=0; i<N; i++) //заполняем значениями
        {
            for(j=0; j<M; j++)
            {
                Massiv[i][j]=(rand ()%50)/10.0;
                cout<<setiosflags(ios::left)<<setw(6)<<Massiv[i][j]; //выравниваем элементы матрицы
            }
            cout<<endl;
        }
        
        double Max=Massiv[0][0];
        for(i=0; i<N; i++) // первый этап: находим максимальный элемент
        {
            for(int j=0; j<M; j++)
            {
                if(Massiv[i][j]>Max)
               {
                    Max=Massiv[i][j];
               }
            }
        }
        double Min=Massiv[0][0];
                for(i=0; i<N; i++) // второй этап: находим максимальный элемент
                {
        for(int j=0; j<M; j++)
        {
                        if(Massiv[i][j]<Min)
            {
                Min=Massiv[i][j];
            }
        }
        }
        double resultat=(Max+Min)/2;
        cout<<"*****************"<<endl;
        cout<<"RESULTAT (srednee ar. min i max): "<<resultat<<endl;
        return;
}
 
  
int main()
{
    srand (time (NULL));
    double D[N][M];
    double A[N][M];
    massiv(D);
    massiv(A);
        getch();
        return 0;
}
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
19.05.2011, 21:57     решить(массивы)! #16
Цитата Сообщение от .Malek. Посмотреть сообщение
а почему когда в main оно разные выдает значения а если в функции то одно и тоже самое?
Потому что вы ее вызывали несколько раз с одним и тем же параметром. Вот она вам и генерировала одинаковые последовательности.
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
19.05.2011, 22:01     решить(массивы)! #17
Вот второе задание
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 <iostream.h>
#include <stdio.h>
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
#include <iomanip.h>
#include <time.h>
const int N=3;
const int M=8;
void massiv(double Massiv[N][M])
 {
        int i, j;
        
                
        cout<<"----Massiv---"<<endl;
        for(i=0; i<N; i++) //заполняем значениями
        {
            for(j=0; j<M; j++)
            {
                Massiv[i][j]=(rand ()%50)/10.0;
                cout<<setiosflags(ios::left)<<setw(6)<<Massiv[i][j]; //выравниваем элементы матрицы
            }
            cout<<endl;
        }
        
        double Max=Massiv[0][0];
        for(i=0; i<N; i++) // первый этап: находим максимальный элемент
        {
            for(int j=1; j<M; j+=2)
            {
                if(Massiv[i][j]>Max)
               {
                    Max=Massiv[i][j];
               }
            }
        }
        double Min=Massiv[0][0];
                for(i=0; i<N; i++) // второй этап: находим максимальный элемент
                {
        for(int j=1; j<M; j+=2)
        {
                        if(Massiv[i][j]<Min)
            {
                Min=Massiv[i][j];
            }
        }
        }
        cout<<"*****************"<<endl;
        cout<<"Max: "<<Max<<" Min: "<<Min<<endl;
        return;
}
 
  
int main()
{
    srand (time (NULL));
    double F[N][M];
    double A[N][M];
    massiv(F);
    massiv(A);
        getch();
        return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.05.2011, 22:06     решить(массивы)!
Еще ссылки по теме:

не могу решить массивы, функции, арифметические операции в С++ C++
Помогите решить задачки на массивы C++
C++ Помогите решить задачу на массивы

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

Или воспользуйтесь поиском по форуму:
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
19.05.2011, 22:06     решить(массивы)! #18
Цитата Сообщение от .Malek. Посмотреть сообщение
C++
1
for(int j=1; j<M; j+=2)
Будьте внимательны. Вы выходите за границы массива в последней итерации цикла.
Yandex
Объявления
19.05.2011, 22:06     решить(массивы)!
Ответ Создать тему
Опции темы

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