Форум программистов, компьютерный форум 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
06.06.2013, 23:00  [ТС]     Если число отрицательных элементов матрицы превышает число положительных, увеличить каждый её элемент на величину среднего арифметического её элем-ов
Кое-что переделала, но в 16 строке - выход за пределы массива, не знаю, как исправить.

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
#include <iostream>
 
 
using namespace std;
 
void task(int **mass,unsigned int N, unsigned int M)
{
int count = 0;
int sum = 0;
unsigned int n,m;
 
for(unsigned int i = 0; i < n;i++)
{
    for(unsigned int j = 0; j < m;j++)
    {
    if(mass[i][j]<0){ count--; }
    else{ count++; }
    sum+=mass[i][j];
    }
}
 
sum /= m*n ;
if(count < 0)
{
    for(unsigned int i = 0; i < n;i++)
    {
        for(unsigned int j = 0; j < m;j++)
        {
        mass[i][j]+=sum;
        }
    }
}
}
 
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);
 
 std::cout<<"Please input some elements: \n";
 
 int **matrix=new int*[n];
 for (unsigned int i = 0; i < n; i++) matrix[i] = new int[m];
 
 for (unsigned int i = 0; i < n; i++)
 
     for (unsigned int j = 0; j < m ; j++)
         scanf("%d", &matrix[i][j]);
 
 std::cout<<"\n";
 std::cout<<"Here is your array: \n";
 for(unsigned int i=0; i<n; i++)
 {
  for(unsigned int j=0; j<m; j++)
  printf("%4d ", matrix[i][j]);
  printf("\n");
  }
 
 
 
 
 task(matrix, n,m);
 
 std::cout<<"\n";
 std::cout<<"The task is done: \n";
 
 for(unsigned int i=0; i<n; i++)
 {
      for(unsigned int j=0; j<m; j++)
              printf("%10d", matrix[i][j]);
              printf("\n");
 }
 system("pause");
 return(0);
}
 
Текущее время: 01:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru