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

В каждой строке матрицы элемент главной диагонали заменить суммой ранее расположенных элементов

19.12.2012, 21:07. Показов 1797. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребята выручайте, до пятницы нужно сделать это задание(( я понимаю, что вы мне не обязаны( но очень надо. Заранее спасибо за помощь.
в каждой строке матрицы F(k,k) элемент, лежащий на главной диагонали, если это простое число, заменить суммой ранее расположенных элементов.
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.12.2012, 21:07
Ответы с готовыми решениями:

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

Элемент, лежащий на главной диагонали, если это простое число, заменить суммой ранее расположенных элементов
Задание: В каждой строке матрицы F(k,k) элемент, лежащий на главной диагонали, если это простое число, заменить суммой ранее расположенных...

Заменить элементы главной диагонали суммой элементов каждой строки матрицы X(m,m).
Заменить элементы главной диагонали суммой элементов каждой строки матрицы X(m,m).

3
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
19.12.2012, 21:23
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <iomanip>
#include <cmath>
 
bool is_prime(int value)
{
    if(value <= 1)
    {
        return 0;
    }
    
    for(int i = 2; i <= sqrt(value); ++i)
    {
        if (value % i==0)
        {
            return 0;
        }
    }
    
    return 1;
}
 
int sum_before(int * arr, int index)
{
    int sum = 0;
    
    for(int i = 0; i < index; ++i)
    {
        sum += arr[i];
    }
    
    return sum;
}
 
void change_elems(int ** matrix, int rows, int cols)
{
    int * diag = new int[rows];
    
    for(int i = 0; i < rows; ++i)
    {
        diag[i] = matrix[i][i];
    }
    
    for(int i = 0; i < rows; ++i)
    {
        if(is_prime(matrix[i][i]))
        {
            matrix[i][i] = sum_before(diag, i);
        }
    }
    
    delete [] diag;
        
}
 
void fill_matrix(int ** matrix, int rows, int cols)
{
    for(int i = 0; i < rows; ++i)
    {
        for(int j = 0; j < cols; ++j)
        {
            matrix[i][j] = rand() % 100;
        }
    }
}
 
void output_matrix(int ** matrix, int rows, int cols)
{
    for(int i = 0; i < rows; ++i)
    {
        for(int j = 0; j < cols; ++j)
        {
            std::cout << std::setw(4) << matrix[i][j] << " ";
        }
        std::cout << "\n";
    }
}
        
 
int main()
{
    srand(static_cast<unsigned int>(time(0))); 
    
    int rows, cols;
 
    std::cout << "Enter rows: ";
    std::cin >> rows;
    std::cout << "Enter cols: ";
    std::cin >> cols;
 
    int ** matrix = new int * [rows];
 
    for(int i = 0; i < rows; ++i)
        matrix[i] = new int[cols];
        
    
    fill_matrix(matrix, rows, cols);
    std::cout << "Source:\n";
    output_matrix(matrix, rows, cols);
    
    change_elems(matrix, rows, cols);
    std::cout << "\nResult:\n";
    output_matrix(matrix, rows, cols);
    
   
    for(int i = 0; i < rows; ++i)
        delete [] matrix[i];
        
    delete [] matrix;
   
    return 0;
}
0
Maria91
20.12.2012, 00:24
Спасибо( но как мне кажеться Вы написали слишком сложно(( мы просто многого из того, что Вы написади неучили мы только new int, динамические и двумерные массивы выучили.( возможно ли как то решить с помощью изученого решить данную задачу( если не получиться ничего страшного(
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
20.12.2012, 07:29
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Цитата Сообщение от Maria91 Посмотреть сообщение
неучили мы только new int, динамические и двумерные массивы выучили
Память malloc'ом что ли выделяли? Тогда замените.

строки 93-96
C++
1
2
3
4
int ** matrix = (int**)malloc(rows *sizeof(int*));
 
for(int i=0;i<rows;i++)
    matrix [i]=(int*)malloc(cols * sizeof(int));
строки 108-111
C++
1
2
3
4
for(int i = 0; i < rows; ++i)
    free(matrix[i]);
        
free(matrix);
Добавлено через 1 минуту
Цитата Сообщение от Maria91 Посмотреть сообщение
заменить суммой ранее расположенных элементов.
Кстати вот тут тоже не совсем ясно. Ранее расположенные элементы это какие? Вообще в матрице или на главной диагонали? (я сделал подсчет сумм элементов на диагонали).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.12.2012, 07:29
Помогаю со студенческими работами здесь

Заменить максимальный элемент матрицы суммой элементов главной диагонали
Уважаемые программисты, очень прошу помочь с решением двух задач на Паскале. 1. Дан массив F(25). Получить их исходного массива два...

В каждой строке матрицы заменить элементы суммой элементов, расположенных справа от него
В матрице Z(6,6) элемент главной диагонали (если он не равен 0) в каждой строке заменить суммой элементов, расположенных справа от ...

Заменить наибольший элемент каждой строки матрицы суммой элементов, расположенных до него
Вот как это все записать? Я в принципе знаю как наибольший элемент найти, ну заменить тоже, а вот с суммой даже не представляю. Но на...

В каждой строке квадратной матрицы определить сумму S1 элементов, расположенных слева от главной диагонали
В каждой строке квадратной матрицы определить сумму S1 элементов, расположенных слева от главной диагонали, и сумму S2 элементов,...

Как найти минимальный элемент в каждой строке матрицы и заменить соответствующим с главной диагонали?
:cry:


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
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. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru