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

Найти попарные суммы элементов строки и столбца матрицы

11.11.2019, 23:51. Показов 2496. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Составить подпрограмму нахождения индексов минимального элемента матрицы. Используя такую подпрограмму, сформировать одномерный массив T, элементами которого являются попарные суммы элементов строки и столбца заданной квадратной матрицы S с номерами, соответственно равными индексам ее минимального элемента.


Вот наработки, осталось сделать этот массив T, но не могу понять само условие составления этих попарных сумм, помогите пожалуйста

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
#include <iostream>
 
using namespace std;
 
void Fill(double** S, int n)    // Функция заполнения массива
{
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n; j++)
            cin >> *(*(A + i) + j);
}
 
double IndexMin (double** S, int n, int im, int jm) // Функция поиска индексов минимального элемента
{
    double min = *(*(S + i) + j);
    
    for (i = 0; i < n; i++)
        for (j = 0; i < n; j++)
            if (*(*(S + i) + j) < min)
            {
                min = *(*(S + i) + j);
                im = i;
                jm = j;
            }
    return im, jm;
}
 
int main()
{
    int n;
    double sum = 0;
    cout << "Input the number of rows and columns:\n"; cin >> n;
 
    double** S = new double* [n];
 
    for (int i = 0; i < n; i++)
        S[i] = new double[n];
    double* T = new double[n];
 
    Fill(S, n);
 
    IndexMin(S, n, im, jm);
 
    
        for (int i = 0; i < n; i++)
        cout << "Sum) " << T[i] << endl;
 
    for (int i = 0; i < n; i++)
        delete[]S[i];
    delete[]S;
        delete[]T;
    system("pause");
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.11.2019, 23:51
Ответы с готовыми решениями:

Найти наибольшее из двух чисел: суммы элементов k-й строки и суммы элементов s-го столбца матрицы
Братки, спасите меня! Не могу решить эту задачу. У меня уже мозга кипит , я ничего не могу с этим дельфи сделать. Мне 14 лет и у нас в...

Определить количество особых элементов матрицы (больших суммы остальных элементов его столбца или строки)
Дана матрица m * n. Определить количество особых(особого) элементов если он больше суммы остальных элементов его столбца или строки.Вывести...

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

3
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
12.11.2019, 00:33
условие конечно сформулировано не очень. как я понимаю, нужно найти индексы первого минимума, например imin, imin и попарно сложить элементы строки с индексом imin c элементами столбца с индексом jmin.
для приведённой матрицы imin=1, jmin=0
T[0]=S[1][0]+S[0][0]
T[1]=S[1][1]+S[1][0]
T[2]=S[1][2]+S[2][0]

Добавлено через 5 минут
Цитата Сообщение от BlvckSnake Посмотреть сообщение
return im, jm;
так 2 значения возвращать нельзя, передавайте их по ссылке как параметры.

Добавлено через 3 минуты
эдесь ошибка в условии
Цитата Сообщение от BlvckSnake Посмотреть сообщение
номерами индексами, соответственно равными индексам ее минимального элемента
зачем Вы пишите с указателями ? такого требования в условии нет
1
0 / 0 / 0
Регистрация: 17.09.2019
Сообщений: 32
12.11.2019, 00:37  [ТС]
Цитата Сообщение от Yetty Посмотреть сообщение
условие конечно сформулировано не очень. как я понимаю, нужно найти индексы первого минимума, например imin, imin и попарно сложить элементы строки с индексом imin c элементами столбца с индексом jmin.
для приведённой матрицы imin=1, jmin=0
T[0]=S[1][0]+S[0][0]
T[1]=S[1][1]+S[1][0]
T[2]=S[1][2]+S[2][0]

Добавлено через 5 минут

так 2 значения возвращать нельзя. передавайте их по ссылке как параметры или пишите 2 отдельных функции.

Добавлено через 3 минуты
эдесь ошибка в условии
Спасибо, теперь примерно понял что хотят)) Я правильно понимаю, что можно написать прямо как вы сделали "T[0]=S[1][0]+S[0][0]" т.к. матрица уже задана или это как-то через указатели можно сделать в динамическим виде для любой матрицы?

Добавлено через 2 минуты
В условии нет, но преподаватель обязывает все в динамике, с указателями и ручным вводом матрицы))
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
12.11.2019, 01:08
Цитата Сообщение от BlvckSnake Посмотреть сообщение
В условии нет, но преподаватель обязывает все в динамике, с указателями и ручным вводом матрицы))
под условие сделал, а что там нужно преподавателю это Вам лучше знать, надеюсь добавите сами
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
void IndexMin (double** S, int n, int &imin, int &jmin) 
{    
    for (int i = 0; i < n; i++)    
        for (int j = 0; j < n; j++)     
        if (S[i][j]<S[imin][jmin]) {imin=i;jmin=j;}
}
 
int main()
{
    srand((int)time(0));
    int n, imin=0, jmin=0;    
    
    cout << "n="; cin >> n;
 
      double **S = new double*[n]; 
    for (int i = 0; i < n; i++)
        S[i] = new double[n];
        
      double *T = new double[n];
      
    cout << "Matrix S:\n";
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
        S[i][j]=rand()%9+ 1;
        cout << S[i][j] << " ";
        }
    cout << "\n";
    }  
 
    IndexMin(S,n,imin,jmin);    
    
    cout << "Array T:\n";
    for (int i = 0; i < n; i++)
        {
        T[i]=S[imin][i]+S[i][jmin];
        cout << T[i] << " ";
        }
    cout << "\n";    
 
    for (int i = 0; i < n; i++)
    delete[]S[i];
    delete[]S;
    delete[]T;
system("pause");
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.11.2019, 01:08
Помогаю со студенческими работами здесь

Определить большее из суммы элементов 3 строки и наибольшего элемента 5 столбца матрицы
В матрице из 5 строк и 5 столбцов определить большее из суммы элементов 3 строки и наибольшего элемента 5 столбца

Найти максимальное значение суммы элементов столбца матрицы.
Дана квадратная матрица 4х4. С использованием двухмерных массивов найти максимальное значение суммы элементов столбца матрицы. Спасибо.

Массив: Найти количества тех элементов матрицы, которые больше суммы остальных элементов своего столбца.
Вечер добрый,помогите пожалуйста. Дана целочисленная матрица из N строки и M столбцов (1&lt;N&lt;=100,1&lt;M&lt;=50).Выполнить заданную...

Для заданной матрицы размера NхN найти такие k и n, что сумма элементов k- столбца матрицы совпадает с суммой элементов n- го строки
Для заданной матрицы размера NхN найти такие k и n, что сумма элементов k- столбца матрицы совпадает с суммой элементов n- го строки. Найти...

Напечатать суммы элементов строки и столбца, на пересечении которых расположен минимальный элемент матрицы
Есть у кого-нибудь код или готовый проект на Delphi 7? Добавлено через 28 минут Напечатать суммы элементов строки и столбца?...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
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. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru