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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Считывание текстовой информации, подсчет мат выражений, если таковые имеются http://www.cyberforum.ru/cpp-beginners/thread884376.html
Собственно имеется текстовый файл, или данные вводятся вручную, суть в том что необходимо отбросить все ненужное и найти только математические выражения, вычислить их результат. Пока есть такой код калькулятора распознает 4 арифм оператора и скобки любой вложенности, работает только с целыми числами, нужна помощь в реализации с вещественными, а так же по возможности проверка на то евляетс ли...
C++ Не получается считать информацию из фаила (описать структуру с именем MARSH) Не получается считать информацию из файла. Все остальные действия программы кроме считывания информации из файла работают нормально. Ошибка кроется между 114 и 128 строками, я не понимаю как её исправить и что там надо дописать,уже попросту не соображаю под вечер,решил обратиться за помощью на форум. Помогите пожалуйста. Условия задачи: Создать однофайловое консольное приложение... http://www.cyberforum.ru/cpp-beginners/thread884369.html
C++ Непоследовательное чтение и запись в файл в одной программе
Здравствуйте ! Нужен совет как реализовать в программе чтение и запись если пользователь сам говорит что делать.
Даны три квадратные матрицы. Сформировать вектор, состоящий из минимальных элементов каждой матрицы, отличных от нуля C++
Даны три квадратные матрицы. Сформировать вектор, состоящий из минимальных элементов каждой матрицы, отличных от нуля. Поиск минимального элемента выполнить в виде процедуры
C++ Дано матрицу А размером 6х5. Заменить в матрице элементы главной диагонали нулями http://www.cyberforum.ru/cpp-beginners/thread884347.html
Дано матрицу А размером 6х5. Заменить в матрице элементы главной диагонали нулями.
C++ Дано одномерный массив Х, состоящий из 15 элементов. Определить пивсуму наибольшего и наименьшего элементов массива Дано одномерный массив Х, состоящий из 15 элементов. Определить пивсуму наибольшего и наименьшего элементов массива подробнее

Показать сообщение отдельно
Locust
1 / 1 / 0
Регистрация: 09.11.2012
Сообщений: 82
29.05.2013, 22:53     Если число отрицательных элементов матрицы превышает число положительных, увеличить каждый её элемент на величину среднего арифметического её элем-ов
Здравствуйте.

Вот задание: Если число отрицательных элементов матрицы превышает число положительных, увеличить каждый её элемент на величину среднего арифметического её элементов. Выделить функции для ввода/вывода массивов и решения задачи.

Задание, по сути, пустячное, но я совсем недавно начала изучать С++, поэтому многого не понимаю. К задаче этой накорябала вот что:

Кликните здесь для просмотра всего текста
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>
using namespace std;
int main()
{
 unsigned int n,m;
 std::cout<<"Please input the number of lines: ";
 scanf("%d", &n);
 std::cout<<"Please input the number of columns: ";
 scanf("%d", &m);
 const size_t N = 10;
 const size_t M = 10;
 
 std::cout<<"Please input some elements: \n";
 int matrix[N][M];
 for (int i = 0; i < n; i++)
     for (int j = 0; j < m ; j++)
         scanf("%d", &matrix[i][j]);
         
 std::cout<<"\n";
 std::cout<<"Here is your array: \n";
 for(int i=0; i<n; i++)
 {
  for(int j=0; j<m; j++)
  printf("%4d", matrix[i][j]);
  printf("\n");
  }
 
 unsigned int pos=0,neg=0;
 for(int i=0; i<n; i++)
 {
 for(int j=0; j<m; j++)
 if (matrix[i][j]<0) {neg++;}
 else {pos++;}
 }
 
 int sum=0;
 for(int i=0; i<n; i++)
 {
 for(int j=0; j<m; j++)
 sum=sum+matrix[i][j];
 }
 float mean=sum/n/m;
 
 std::cout<<"\n";
 if (neg>pos)
 {
 for(int i=0; i<n; i++)
 {
 for(int j=0; j<m; j++)
 matrix[i][j]=matrix[i][j]+mean;
 }
 std::cout<<"Number of negative elements in the array is greater than number of the positive ones. Let us change our array: \n";
 for(int i=0; i<n; i++)
 {
  for(int j=0; j<m; j++)
  printf("%10d", matrix[i][j]);
  printf("\n");
  }
 }
 else {std::cout<<"Number of positive elements in the array is greater than number of the negative ones.\n";}
 
  system("pause");
  return(0);
}


Код ещё совсем сырой: нуль считается числом положительным, а также пока не прописала, что делать, если количество положительных и отрицательных элементов равно; функции не выделяла. Потому что возникла небольшая проблема: среднее арифметическое программа вычисляет, а вот при попытке увеличить на него каждый элемент матрицы выдаёт какую-то ересь. Подскажите, пожалуйста, в чём может быть проблема.
Буду также очень благодарна за любую конструктивную критику и полезные советы.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru