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

Из заданной матрицы сформировать одномерный массив; найти среднее арифметическое элементов полученного массива

15.09.2016, 23:13. Показов 4044. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана целочисленная прямоугольная матрица размера n x m. Сформировать одномерный массив, состоящий из элементов, лежащих на отрезке [a,b]. Найти среднее арифметическое полученного одномерного массива.

Нигде эту задачу найти не могу ищу больше 2 часов. Самому решить не вариант никак. Очень срочно практика горит, помогите пожалуйста !!!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.09.2016, 23:13
Ответы с готовыми решениями:

Сформировать одномерный массив из элементов, стоящих над главной диагональю матрицы K(m,m). Найти сумму элементов этого массива.
Сформировать одномерный массив из элементов, стоящих над главной диагональю матрицы K(m,m). Найти сумму элементов этого массива.

Сформировать одномерный массив Х из положительных элементов матрицы А, найти минимальный элемент массива Х и его номер
Доброго всем времени суток) никак не могу создать массив из матрицы( кто поумнее меня , помогите плиз) Вот задание: ...

Сформировать одномерный массив Х из элементов верхнего левого треугольника матрицы А и найти максимальный элемент массива Х
Народ, помогите пожалуйста! Сформировать одномерный массив Х из элементов верхнего левого треугольника матрицы А и найти максимальный...

9
 Аватар для Fulcrum_013
2083 / 1575 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
16.09.2016, 00:22
Цитата Сообщение от Алексейпант Посмотреть сообщение
Самому решить не вариант никак. Очень срочно практика горит, помогите пожалуйста !!!
Дык и работать по специальности тогда никак. Зачем вам тогда практика и диплом программиста?
0
0 / 0 / 0
Регистрация: 15.09.2016
Сообщений: 15
16.09.2016, 09:40  [ТС]
Я написал на Pascal, но нужно на C++, если знаете напишите, буду Вам признателен ! 17 сентября отчет по практике сдать нужно а без задачи не примут.
0
 Аватар для SW Developer
97 / 93 / 81
Регистрация: 10.01.2016
Сообщений: 663
Записей в блоге: 13
16.09.2016, 11:38
Выкладывайте на Pascal, на С++ будет проще перевести и быстрее.
0
132 / 158 / 87
Регистрация: 06.04.2016
Сообщений: 992
16.09.2016, 12:28
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
//---------------------------------------------------------------------------
#include <vcl.h>
#include <iostream.h>
#include <conio.h>
#pragma hdrstop
//---------------------------------------------------------------------------
#pragma argsused
int main(int argc, char* argv[])
{
int x, y, A, B, z, Razmer;
int MN[10][20];
srand(time(NULL));
for(x = 0; x < 10; x++)
    for(y = 0; y < 20; y++)
        MN[x][y] = rand()%500 - 250;
 
cout << "Massiv MN:\n";
for(x = 0; x < 10; x++){
    for(y = 0; y < 20; y++){
        cout << MN[x][y];
        cout << " ";
        }
    cout << "\n";
    }
cout << "Vvedite chslo A:";
cin >> A;
cout << "Vvedite chslo B:";
cin >> B;
if(A > B){
    cout << "Vvedeni nepravilnie chisla A i B.";
    getch();
    return 1;
    }
//Opredelyaem chilslo zifr vhodyashih v diapazon
z = 0;
for(x = 0; x < 10; x++)
    for(y = 0; y < 20; y++)
        if((MN[x][y] >= A)&&(MN[x][y] <= B)) z++;
Razmer = z;
int *Diapazon = new int[z];
z = 0;
for(x = 0; x < 10; x++)
    for(y = 0; y < 20; y++)
        if((MN[x][y] >= A)&&(MN[x][y] <= B)){
            Diapazon[z] = MN[x][y];
            z++;
            }
cout << "Razmer massiva Diapazon:" << Razmer << "\n";            
cout << "Pechataem massiv Diapazon:";
for(x = 0; x < Razmer; x++){
    cout << Diapazon[x];
    if(x != (Razmer-1)) cout << " ";
    }
 
getch();
return 0;
}
//---------------------------------------------------------------------------
C++Builder 6.
1
0 / 0 / 0
Регистрация: 15.09.2016
Сообщений: 15
16.09.2016, 14:35  [ТС]
спасибо большое !)

Добавлено через 5 минут
А упростить этот код никак ?
0
132 / 158 / 87
Регистрация: 06.04.2016
Сообщений: 992
16.09.2016, 19:07
Упростить код вряд-ли как-то можно. А среднее арифметическое-то я забыл посчитать!
Вот оно:
Вначале блок переменных нужно доработать вот так:
C++
1
2
3
int x, y, A, B, z, Razmer, Summa;
float SA;
int MN[10][20];
Строки 50-53 включительно нужно заменить на эти:
C++
1
2
3
4
5
6
7
8
Summa = 0;
for(x = 0; x < Razmer; x++){
    cout << Diapazon[x];
    if(x != (Razmer-1)) cout << " ";
    Summa += Diapazon[x];
    }
SA = (float)Summa/Razmer;
cout << "\n" << "Srednee Arifmeticheskoe=" << SA;
1
0 / 0 / 0
Регистрация: 15.09.2016
Сообщений: 15
19.09.2016, 17:22  [ТС]
Спасибо тебе большое ты меня очень сильно выручил !!!
0
Модератор
Эксперт CЭксперт С++
 Аватар для sourcerer
5288 / 2376 / 342
Регистрация: 20.02.2013
Сообщений: 5,773
Записей в блоге: 20
20.09.2016, 09:27
Цитата Сообщение от DemolitionMan Посмотреть сообщение
Упростить код вряд-ли как-то можно.
DemolitionMan, весьма самоуверенное заявление.

Алексейпант, не скажу, что мой код сильно проще (смотря с какой стороны посмотреть). Если делать чисто на функциях в императивном стиле, без всяких классов, STL и без C++11:
main.cpp

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
#include "arrays_functions.h"
#include <iostream>
#include <cstdlib>
 
 
int main()
{
    size_t row_size;
    size_t col_size;
 
    get_number_from_user( "Enter number of rows: ", row_size );
    get_number_from_user( "Enter number of columns: ", col_size );
 
    int ** matrix = create( row_size, col_size );
 
    const size_t from_num = 10;
    const size_t to_num = 99;
 
    fill_rand( matrix, row_size, col_size, from_num, to_num );
    show( matrix, row_size, col_size );
 
    size_t arr_size;
    get_number_from_user( "Enter size of array: ", arr_size );
 
    int * array = create( arr_size );
 
    const size_t begin_row_index = 0;
    const size_t begin_col_index = 0;
 
    fill_array_from_part_of_matrix
        (
            array,
            arr_size,
            matrix,
            row_size,
            col_size,
            begin_row_index,
            begin_col_index
        );
    show( array, arr_size );
 
    std::cout
        << "Arithmetic mean of array's values is: "
        << calc_arithm_mean( array, arr_size );
 
    destroy( matrix, row_size );
    destroy( array );
 
    return 0;
}

arrays_functions.h

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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#ifndef ARRAYS_FUNCTIONS_H
#define ARRAYS_FUNCTIONS_H
 
#include <cstdlib>
#include <string>
 
// Function prototypes to handle 1-dimensional arrays:
//--------------------------------------------------
int * create
    (
        const size_t arr_size
    );
 
//--------------------------------------------------
void destroy
    (
        int * array
    );
 
//--------------------------------------------------
void fill_rand
    (
        int * array,
        const size_t arr_size,
        const int from_num,
        const int to_num
    );
 
//--------------------------------------------------
void show
    (
        int * array,
        const size_t arr_size
    );
 
//--------------------------------------------------
int calc_sum_of_values
    (
        int * array,
        const size_t arr_size
    );
 
//--------------------------------------------------
int calc_arithm_mean
    (
        int * array,
        const size_t arr_size
    );
 
// Function prototypes to handle matrices:
//--------------------------------------------------
int ** create
    (
        const size_t row,
        const size_t col
    );
 
 
//--------------------------------------------------
void destroy
    (
        int ** matrix,
        const size_t row
    );
 
//--------------------------------------------------
void fill_rand
    (
        int ** matrix,
        const size_t row,
        const size_t col,
        const int from_num,
        const int to_num
    );
 
//--------------------------------------------------
void show
    (
        int ** matrix,
        const size_t row,
        const size_t col
    );
 
//--------------------------------------------------
int calc_sum_of_values
    (
        int ** matrix,
        const size_t row,
        const size_t col
    );
 
//--------------------------------------------------
int calc_arithm_mean
    (
        int ** matrix,
        const size_t row,
        const size_t col
    );
 
// Other function prototypes:
//--------------------------------------------------
void get_number_from_user
    (
        std::string promt,
        size_t & number
    );
 
//--------------------------------------------------
void fill_array_from_part_of_matrix
    (
        int * array,
        const size_t arr_size,
        int ** matrix,
        const size_t row,
        const size_t col,
        const size_t begin_row_index,
        const size_t begin_col_index
    );
 
#endif // ARRAYS_FUNCTIONS_H

arrays_functions.cpp

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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
#include "arrays_functions.h"
#include <iostream>
#include <ctime>
 
// Function implementations to handle 1-dimensional arrays:
//--------------------------------------------------
int * create
    (
        const size_t arr_size
    )
{
    int * array = new int[arr_size];
    return array;
}
 
//--------------------------------------------------
void destroy
    (
        int * array
    )
{
    delete [] array;
}
 
//--------------------------------------------------
void fill_rand
    (
        int * array,
        const size_t arr_size,
        const int from_num,
        const int to_num
    )
{
    static bool first_time_in_this_program = true;
    if ( first_time_in_this_program )
    {
        srand( time( NULL ) );
        first_time_in_this_program = false;
    }
 
    for ( size_t i = 0; i < arr_size; ++i )
        array[i] = rand() % (to_num - from_num) + from_num;
}
 
//--------------------------------------------------
void show
    (
        int * array,
        const size_t arr_size
    )
{
    std::cout << "\n";
    for ( size_t i = 0; i < arr_size; ++i )
    {
        std::cout << array[i] << " ";
    }
    std::cout << "\n\n";
}
 
//--------------------------------------------------
int calc_sum_of_values
    (
        int * array,
        const size_t arr_size
    )
{
    int sum = 0;
    for ( size_t i = 0; i < arr_size; ++i )
        sum += array[i];
 
    return sum;
}
 
//--------------------------------------------------
int calc_arithm_mean
    (
        int * array,
        const size_t arr_size
    )
{
    int sum = calc_sum_of_values( array, arr_size );
    return sum / arr_size;
}
 
// Function implementations to handle matrices:
//--------------------------------------------------
int ** create
    (
        const size_t row,
        const size_t col
    )
{
    int ** matrix = new int * [row];
    for ( size_t i = 0; i < row; ++i )
        matrix[i] = new int[col];
 
    return matrix;
}
 
//--------------------------------------------------
void destroy
    (
        int ** matrix,
        const size_t row
    )
{
    for ( size_t i = 0; i < row; ++i )
        delete [] matrix[i];
    delete [] matrix;
}
 
//--------------------------------------------------
void fill_rand
    (
        int ** matrix,
        const size_t row,
        const size_t col,
        const int from_num,
        const int to_num
    )
{
    static bool first_time_in_this_program = true;
    if ( first_time_in_this_program )
    {
        srand( time( NULL ) );
        first_time_in_this_program = false;
    }
 
    for ( size_t i = 0; i < row; ++i )
        for ( size_t j = 0; j < col; ++j )
            matrix[i][j] = rand() % (to_num - from_num) + from_num;
}
 
//--------------------------------------------------
void show
    (
        int ** matrix,
        const size_t row,
        const size_t col
    )
{
    std::cout << "\n";
    for ( size_t i = 0; i < row; ++i )
    {
        for ( size_t j = 0; j < col; ++j )
        {
            std::cout << matrix[i][j] << " ";
        }
        std::cout << "\n";
    }
    std::cout << "\n";
}
 
//--------------------------------------------------
int calc_sum_of_values
    (
        int ** matrix,
        const size_t row,
        const size_t col
    )
{
    int sum = 0;
    for ( size_t i = 0; i < row; ++i )
        for ( size_t j = 0; j < col; ++j )
            sum += matrix[i][j];
 
    return sum;
}
 
//--------------------------------------------------
int calc_arithm_mean
    (
        int ** matrix,
        const size_t row,
        const size_t col
    )
{
    int sum = calc_sum_of_values( matrix, row, col );
    return sum / (row * col);
}
 
// Other function implementations:
//--------------------------------------------------
void get_number_from_user
    (
        std::string promt,
        size_t & number
    )
{
    std::cout << promt;
    std::cin >> number;
}
 
//--------------------------------------------------
void fill_array_from_part_of_matrix
    (
        int * array,
        const size_t arr_size,
        int ** matrix,
        const size_t row,
        const size_t col,
        const size_t begin_row_index,
        const size_t begin_col_index
    )
{
    for ( size_t i = begin_row_index, k = 0; i < row; ++i )
    {
        for
            (
                size_t j = begin_col_index;
                j < col && k < arr_size;
                ++j, ++k
            )
        {
            array[k] = matrix[i][j];
        }
    }
}
Миниатюры
Из заданной матрицы сформировать одномерный массив; найти среднее арифметическое элементов полученного массива  
0
Модератор
Эксперт CЭксперт С++
 Аватар для sourcerer
5288 / 2376 / 342
Регистрация: 20.02.2013
Сообщений: 5,773
Записей в блоге: 20
20.09.2016, 10:12
Конечно, можно сделать красивее:
  • можно сделать вместо всех этих функций пользовательские классы Array и Matrix (либо один класс - N_DimArray)
  • можно воспользоваться готовым классом array из STL и matrix или MultiArray из Boost
  • можно сделать с помощью std::vector из, опять же, STL (матрицей будет вектор векторов)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.09.2016, 10:12
Помогаю со студенческими работами здесь

Переписать в одномерный массив элементы матрицы, превосходящие среднее арифметическое ее положительных элементов
задание: Составить функцию переписывающую из матрицы А в одномерный массив элементы, превосходящие среднее арфметическое положительных...

Одномерный массив, найти среднее арифметическое отрицательных элементов
подскажите пожалуйста как решить: Дано два массива а (n) и в (n) .Найти среднее арифметическое отрицательных элементов в двух массивах....

Сформировать массив X из элементов массива A, значения которых не превышают среднее арифметическое массива A
Помогите с выводом массива X пожалуйста никак не получается по нормальному(( и если можно осуществить сдвиг вправо на две позиции. ...

Для заданной квадратной матрицы сформировать одномерный массив из ее диагональных элементов
Для заданной квадратной матрицы сформировать одномерный массив из ее диагональных элементов. Найти след матрицы, суммируя элементы...

Для заданной квадратной матрицы сформировать одномерный массив из ее диагональных элементов
Для заданной квадратной матрицы сформировать одномерный массив из ее диагональных элементов.с++


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
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
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru