Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.67
boyazhovkostya
0 / 0 / 0
Регистрация: 27.12.2010
Сообщений: 33
#1

Найти максимальный элемент и среднее арифметическое отрицательных элементов матрицы - C++

19.02.2011, 16:27. Просмотров 1553. Ответов 18
Метки нет (Все метки)

Дана матрица состоящая из N,M вещественных элементов.
1.Найти максимальный элемент
2.Вычислить средееарифметическое отрицательных элементов массива
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.02.2011, 16:27
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти максимальный элемент и среднее арифметическое отрицательных элементов матрицы (C++):

Найти среднее арифметическое отрицательных элементов матрицы - C++
найти среднее арифметическое отрицательных элементов матрицы лежащей ниже главной диагонали и среднее арифметическое главной диагонали ...

Найти максимальный элемент одномерного массива и среднее арифметическое его положительных элементов - C++
Передача массивов в функцию (одномерные массивы) Дан одномерный массив, состоящий из N вещественных элементов. Найти максимальный...

Найти среднее арифметическое Sro всех отрицательных элементов матрицы - C++
Найти среднее арифметическое Sro всех отрицательных элементов матрицы {aij}, где i = j = 1, ..., 4.

Найти среднее арифметическое отрицательных элементов матрицы, расположенных в чётных строках - C++
Прошу помочь в написании программы, но никак не могу понять как ее написать :( В матрице Z(n,n), сформированной случайным образом, найти...

Массив: Найти среднее арифметическое элементов матрицы и сумму элементов тех строк матрицы, в которых отрицателен элемент главной диагонали. - C++
Ребят не понимаю я с++ Дали создать программу Помогите пожалуйста Найти среднее арифметическое элементов матрицы и сумму элементов...

Найти среднее арифметическое отрицательных элементов матрицы. Нужна программа и блок схема - C++
Помогите написать программу и блок схему. Найти среднее арифметическое отрицательных элементов матрицы, а также посчитать сколько таких...

18
asics
Freelance
Эксперт С++
2850 / 1785 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
19.02.2011, 16:40 #2
Цитата Сообщение от boyazhovkostya Посмотреть сообщение
1.Найти максимальный элемент
C++
1
2
3
4
5
max = matr[0][0];
for(int i = 0; i < N; ++i)
  for(int j = 0; j < M; ++j)
    if(matr[i][j] > max)
      max = matr[i][j];
Цитата Сообщение от boyazhovkostya Посмотреть сообщение
2.Вычислить средееарифметическое отрицательных элементов массива
C++
1
2
3
4
5
6
7
8
9
double sum = 0.0;
size_t cnt = 0;
for(int i = 0; i < N; ++i)
  for(int j = 0; j < M; ++j)
    if(matr[i][j] < 0){
      ++cnt;
      sum += matr[i][j];
    }
std::cout << ( sum / cnt );
1
boyazhovkostya
0 / 0 / 0
Регистрация: 27.12.2010
Сообщений: 33
19.02.2011, 17:14  [ТС] #3
а типа как это сделать в одной программе.и чтоб работало
0
asics
Freelance
Эксперт С++
2850 / 1785 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
19.02.2011, 17:16 #4
boyazhovkostya, Запхните код(см. выше) в main().
1
boyazhovkostya
0 / 0 / 0
Регистрация: 27.12.2010
Сообщений: 33
19.02.2011, 17:17  [ТС] #5
C++
1
2
3
double sum = 0.0;
size_t cnt = 0;
std::cout << ( sum / cnt );
и можешь пожалуйста пояснить эти строчки
0
asics
Freelance
Эксперт С++
2850 / 1785 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
19.02.2011, 17:22 #6
Омг, кажеться вам сюда
0
Sokolov
42 / 42 / 3
Регистрация: 04.01.2011
Сообщений: 125
19.02.2011, 17:25 #7
Цитата Сообщение от asics Посмотреть сообщение
size_t cnt = 0;
Мне тож вот эта строчка инересна.
Что она делает?

Добавлено через 1 минуту
Цитата Сообщение от Sokolov Посмотреть сообщение
Мне тож вот эта строчка инересна.
Что она делает?
Хотя, уже нашел =)

"Тип size_t обычно применяется для счетчиков циклов, индексации массивов, хранения размеров, адресной арифметики."
Но все-таки хочу узнать чем он лучше int?
1
boyazhovkostya
0 / 0 / 0
Регистрация: 27.12.2010
Сообщений: 33
19.02.2011, 17:35  [ТС] #8
C++
1
2
3
double sum = 0.0;
size_t cnt = 0;
std::cout << ( sum / cnt );
а за место этого(size_t cnt) можно int?
и че здесь в первой строчке =0.0?
а тут size_t cnt=0?
0
Sokolov
42 / 42 / 3
Регистрация: 04.01.2011
Сообщений: 125
19.02.2011, 17:44 #9
Цитата Сообщение от boyazhovkostya Посмотреть сообщение
а за место этого(size_t cnt) можно int?
Можно, но size_t видимо чем-то лучше.

Цитата Сообщение от boyazhovkostya Посмотреть сообщение
и че здесь в первой строчке =0.0?
потому что double-тип с плавающей точкой.
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
19.02.2011, 17:51 #10
Вообще size_t - синоним типа unsigned int. Счётчик по смыслу не может принимать отрицательные значения, а size_t приятнее и быстрее писать, чем unsigned.
2
Sokolov
42 / 42 / 3
Регистрация: 04.01.2011
Сообщений: 125
19.02.2011, 17:52 #11
Цитата Сообщение от silent_1991 Посмотреть сообщение
Вообще size_t - синоним типа unsigned int. Счётчик по смыслу не может принимать отрицательные значения, а size_t приятнее и быстрее писать, чем unsigned.
а для size_t библиотек дополнительных не нужно подключать?
1
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
19.02.2011, 18:08 #12
Sokolov, нет.
2
boyazhovkostya
0 / 0 / 0
Регистрация: 27.12.2010
Сообщений: 33
20.02.2011, 15:10  [ТС] #13
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include "stdafx.h"
#include <iostream>
#include "math.h"
using namespace std;
void main()
{
max = matr[0][0];
for(int i = 0; i < N; ++i)
  for(int j = 0; j < M; ++j)
    if(matr[i][j] > max)
      max = matr[i][j];
 
double sum = 0.0;
size_t cnt = 0;
for(int i = 0; i < N; ++i)
  for(int j = 0; j < M; ++j)
    if(matr[i][j] < 0){
      ++cnt;
      sum += matr[i][j];
    }
std::cout << ( sum / cnt );
}
и шо она не работает?
вот какие ошибки выдает
cpp(7): error C2065: matr: необъявленный идентификатор
cpp(8): error C2065: N: необъявленный идентификатор
cpp(9): error C2065: M: необъявленный идентификатор
cpp(10): error C2065: matr: необъявленный идентификатор
cpp(11): error C2065: matr: необъявленный идентификатор
cpp(15): error C2065: N: необъявленный идентификатор
cpp(16): error C2065: M: необъявленный идентификатор
cpp(17): error C2065: matr: необъявленный идентификатор
cpp(19): error C2065: matr: необъявленный идентификатор
0
asics
Freelance
Эксперт С++
2850 / 1785 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
20.02.2011, 15:17 #14
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
#include <iostream>
#include <cmath>
#include <cstdlib>
#include <ctime>
using namespace std;
int main()
{
srand(time(0));
const int N = 3, M = 4;
int matr[N][M];
for(int i = 0; i < N; ++i)
for(int j = 0; j < M; ++j)
matr[i][j] = rand() % 20 - 50;
double max = matr[0][0];
for(int i = 0; i < N; ++i){
for(int j = 0; j < M; ++j)
if(matr[i][j] > max)
max = matr[i][j];
}
double sum = 0.0;
size_t cnt = 0;
for(int i = 0; i < N; ++i){
for(int j = 0; j < M; ++j)
if(matr[i][j] < 0){
++cnt;
sum += matr[i][j];
}
}
cout <<  max << ' ' << ( sum / cnt );
return 0;
}
0
boyazhovkostya
0 / 0 / 0
Регистрация: 27.12.2010
Сообщений: 33
02.03.2011, 18:12  [ТС] #15
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
#include <iostream>
#include "stdafx.h"
#include"math.h"
using namespace std;
int main()
{
srand(time(0));
const int N = 3, M = 4;
int matr[N][M];
for(int i = 0; i < N; ++i)
for(int j = 0; j < M; ++j)
matr[i][j] = rand() % 20 - 50;
double max = matr[0][0];
for(int i = 0; i < N; ++i){
for(int j = 0; j < M; ++j)
if(matr[i][j] > max)
max = matr[i][j];
}
double sum = 0.0;
size_t cnt = 0;
for(int i = 0; i < N; ++i){
for(int j = 0; j < M; ++j)
if(matr[i][j] < 0){
++cnt;
sum += matr[i][j];
}
}
cout <<  max << ' ' << ( sum / cnt );
return 0;
}
 Комментарий модератора 
Используйте теги форматирования кода

cpp(7): error C3861: srand: идентификатор не найден
cpp(7): error C3861: time: идентификатор не найден
cpp(12): error C3861: rand: идентификатор не найден
cpp(28): error C2065: cout: необъявленный идентификатор
0
02.03.2011, 18:12
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.03.2011, 18:12
Привет! Вот еще темы с ответами:

Матрицы: найти количество, сумму и среднее арифметическое отрицательных элементов в каждой строке - C++
дан двумерный массив, найти количество, сумму и среднее арифметическое отрицательных элементов в каждой строке

Если максимальный элемент находится левее минимального, то найти среднее арифметическое элементов, находящихся между максимальным и минимальным. - C++
Дан вектор размерности N. Если максимальный элемент находится левее минимального, то найти среднее арифметическое элементов, находящихся...

Найти максимальный элемент среди отрицательных элементов матрицы, расположенных над побочной диагональю - C++
Помогите пожалуйста составить программу на C++: Дана матрица A(4,4) Найти максимальный элемент среди отрицательных элементов матрицы...

Для каждой строки матрицы определить максимальный отрицательный элемент и среднее арифметическое положительных - C++
Здравствуйте. Помогите пожалуйста написать программу: С клавиатуры вводятся два целых числа – М и К. 1&lt;M&lt;10, 1&lt;K&lt;10. (М – число...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.