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

Обработка матрицы

27.09.2015, 17:42. Показов 602. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана целочисленная квадратная матрица. Определить:
1) сумму элементов в тех столбцах, которые содержат хотя бы один отрицательный элемент;
2) номера той строки, в которой сумма положительных элементов максимальна.
Каждый пункт задания оформить в виде отдельной функции.

С первым пунктом более менее разобрался, вот второй никак не хочет. Как правильно передать массив в функцию?

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
#include <iostream.h>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
//îáúÿâëÿåì ôóíêöèþ ñóììû
void SumStlb(int *s, int *p);
void SumStlb(int *s, int *p)
{
    *s = *s + *p;
}
void NomerStr(int **mas1, int n);
void NomerStr(int **mas1, int n)
{
    int m = 0;
    int k = 0;
    int l = 0;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            l = l + mas1[i][j];
            k = j;
        }
        if (l >= m)
        {
            m = l;
            k = j;
        }
    }
 cout<< m << l; 
}
void main()
{
int a, c, n;
int s = 0;
cout << "Vvedite Razmer massiva" << endl;
cin >> n;
cout << "Diapazon" << endl;
cin >> a >> c;
cout <<"Ishodnyi massiv"<<endl;
srand((unsigned)time(NULL));
//ñîçäàåì äèíàìè÷åñêèé äâóìåðíûé ìàññèâ
int **mas1 = new int*[n];
for (int i = 0; i < n; i++)
{
        mas1[i] = new int [n];
}
//çàïîëíÿåì ìàññèâ
for (i = 0; i < n; i++)
{
        for (int j = 0; j < n; j++)
        {
               mas1[i][j] = (rand() % (c - a )+ a);
              
        }
}
//âûâîäèì ìàññèâ
for (i = 0; i < n; i++)
{
        for (int j = 0; j < n; j++)
        {
               cout<<mas1[i][j]<<" ";
        }
        cout<<endl;
}
//ïðîâåðÿåì íà îòðèöàòåëüíûé ýëåìåíò
for (int j = 0; j < n; j++)
{
        for (i = 0; i < n; i++)
        {
               if (mas1[i][j] < 0)
               {
                   for (int g = 0; g < n; g++)
                   {
                       SumStlb(&s, &mas1[g][j]);
                   }
                  break;
               }
               
              
        }
}
cout<<"Summa stolbika c elementom < 0"<< endl;
cout<< s <<endl;
NomerStr(mas1, n);
getch();
}
Добавлено через 2 часа 30 минут
Сделал как-то так, если кто может оформить покрасивее, прошу помочь.


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
#include <iostream.h>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
//объявляем функцию суммы
void SumStlb(int *s, int *p);
void SumStlb(int *s, int *p)
{
    *s = *s + *p;
}
//функция номера строки с наиб. суммой
void NumStr(int sum, int l, int *maxsum,bool count);
void NumStr(int sum, int l, int *maxsum,bool count)
{
    int a = 0;
    int b = 0;
    int c = 0;
    if ((sum > *maxsum) && (count == 0))
    {
        *maxsum = sum;
    }
    if ((*maxsum == sum) && (count == 1))
    {
        cout<<l<<" ";
    }
 
}
void main()
{
int a, c, n, l;
int s = 0;
int sum = 0;
int maxsum = 0;
bool count = 0;
cout << "Vvedite Razmer massiva" << endl;
cin >> n;
cout << "Diapazon" << endl;
cin >> a >> c;
cout <<"Ishodnyi massiv"<<endl;
srand((unsigned)time(NULL));
//создаем динамический двумерный массив
int **mas1 = new int*[n];
for (int i = 0; i < n; i++)
{
        mas1[i] = new int [n];
}
//заполняем массив
for (i = 0; i < n; i++)
{
        for (int j = 0; j < n; j++)
        {
               mas1[i][j] = (rand() % (c - a )+ a);
              
        }
}
//выводим массив
for (i = 0; i < n; i++)
{
        for (int j = 0; j < n; j++)
        {
               cout<<mas1[i][j]<<" ";
        }
        cout<<endl;
}
//проверяем на отрицательный элемент
for (int j = 0; j < n; j++)
{
        for (i = 0; i < n; i++)
        {
               if (mas1[i][j] < 0)
               {
                   for (int g = 0; g < n; g++)
                   {
                       SumStlb(&s, &mas1[g][j]);
                   }
                  break;
               }
               
              
        }
}
cout<<"Summa stolbikov c elementom < 0"<< endl;
cout<< s <<endl;
 
 
//считаем суммы строк, передаем данные в функцию
for (i = 0; i < n; i++)
{
        for (int j = 0; j < n; j++)
        {
               sum = sum + mas1[i][j];
               l = i;
               
        }
    NumStr(sum, l, &maxsum, count); 
    sum = 0;
}
cout<<"Max summa "<< endl;
cout<<maxsum<<endl;
cout<<"Nomera strok s maxsum"<< endl;
count = 1;
sum = 0;
//находим строки с максимальной суммой
for (i = 0; i < n; i++)
{
        for (int j = 0; j < n; j++)
        {
               sum = sum + mas1[i][j];
               l = i;
               
        }
    NumStr(sum, l, &maxsum, count);
    sum = 0;
}
cout<<endl;
getch();
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.09.2015, 17:42
Ответы с готовыми решениями:

Обработка матрицы
Задана действительная квадратная матрица А размерностью n*n. Получить последовательность действительных чисел B1,B2,....,Bn за правилом:...

Обработка матрицы
Есть vector&lt; vector&lt; int &gt; &gt; m. Прохожу по каждой строчке и ищу максимальный элемент: for(int i = 0; i &lt; m.size(); i++) { int...

Обработка матрицы
Составить программу для решения задач, с обязательным использованием подпрограммы для ввода матрицы с экрана, ее обработки и вывода на...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.09.2015, 17:42
Помогаю со студенческими работами здесь

Обработка матрицы
Дана действительная матрица размера 3х4. Определить, сколько раз встречается число 5 во второй строке данной матрицы.

Обработка матрицы
Найти в каждой строке матрицы минимальный элемент и расположить строки по возрастанию этих элементов. Заранее спасибо

Обработка матрицы
найдите ошибку #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;Russian&quot;); ...

Обработка матрицы
Дан массив А. Получить массив В(5) по следующим правилам: В(і)=1 если в і-ой строке массива есть хотябы один отрицательлный элемент, иначе...

Обработка матрицы
функции. пусть дана матрица А(m на n). постройте вектор, каждый элемент которого равен сумме элементов i-й строки матрицы A, больших, чем...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru