2 / 2 / 2
Регистрация: 10.10.2016
Сообщений: 142

Заменить нулями в матрице элементы с чётной суммой индексов

18.10.2016, 09:37. Показов 3121. Ответов 6
Метки с (Все метки)

Author24 — интернет-сервис помощи студентам
Даны целые числа а1, ... , а10, целочисленная квадратная матрица порядка n. Заменить нулями в матрице те елементы с четной суммой индексов, для которых имеются равные среди а1, ... , а10.
Помогите, плиз!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.10.2016, 09:37
Ответы с готовыми решениями:

Заменить нулями в матрице элементы с четной суммой индексов, которые имеются в заданном массиве
Даны целые числа a1, ... ,a10, целочисленная квадратная матрица порядка n. Заменить нулями в матрице те элементы с четной суммой индексов,...

Необходимо заменить нулями в матрице элементы с четной суммой индексов, которые имеются в заданном массиве
Даны целые числа a1, ... , a10, целочисленная квадратная матрица порядка n. Заменить нулями в матрице те элементы с четной суммой индексов,...

Заменить нулями в матрице элементы с четной суммой индексов, значения которых имеются в заданном массиве
Здравствуйте!!! Помогите пожалуйста с задачей))) Даны целые числа a1, ..., an, действительная квадратная матрица порядка n. Заменить...

6
27 / 27 / 37
Регистрация: 11.09.2014
Сообщений: 68
18.10.2016, 10: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
#include <iostream>
using namespace std;
/*Даны целые числа а1, ... , а10, целочисленная квадратная матрица порядка n. Заменить нулями в матрице те елементы с четной суммой индексов, для которых имеются равные среди а1, ... , а10.
 Помогите, плиз!
 */
int main(int argc, const char * argv[]) {
    srand(time(NULL));
    int n, arr[9], mat[20][20];
    cout << "Введите 10 целых чисел:\n";
    for (int i = 0; i <= 9; i++) {
        cin >> arr[i];
    }
    cout << "n = ";
    cin >> n;
    cout << "Исходная матрица: \n";
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            mat[i][j] = rand()%10;
            cout << mat[i][j] << " ";
        }
        cout << endl;
    }
    cout << "Преобразованная матрица:  \n";
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            for (int k = 0; k <= 9; k++) {
                if ((i+j)%2 == 0 && mat[i][j] == arr[k]) {
                    mat[i][j] = 0;
                }
            }
            cout << mat[i][j] << " ";
        }
        cout << endl;
    }
    return 0;
}
1
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
18.10.2016, 10: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
#include <iostream>
 
using namespace std;
 
int main() 
{
    const int N = 20;
    int A[N][N] = { { 0 } };
 
    for (int row = 0; row < N; row++)
    {
        for (int col = 0; col < N; col++)
        {
            A[row][col] = std::rand() % 9 + 1;
            std::cout << A[row][col] << " ";
        }
 
        std::cout << endl;
    }
 
    std::cout << endl;
 
    for (int row = 0; row < N; row++)
        for (int col = 0; col < N; col++)
            if (((row + col) % 2) == 0)
            {
                int r_fwd = 0, c_fwd = 0;
                while (r_fwd < N)
                {
                    if (c_fwd >= N) { c_fwd = 0; r_fwd++; }
                    if (A[r_fwd][c_fwd] == A[row][col] && r_fwd != row && c_fwd != col) 
                        A[r_fwd][c_fwd] = 0;
 
                    c_fwd++;
                }
            }
 
    for (int row = 0; row < N; row++)
    {
         for (int col = 0; col < N; col++)
              std::cout << A[row][col] << " ";
         
         std::cout << endl;
    }
 
    std::cout << endl << endl;
 
    std::cin.get();
}
Миниатюры
Заменить нулями в матрице элементы с чётной суммой индексов  
1
Объявлятель переменных
 Аватар для SpBerkut
1220 / 406 / 320
Регистрация: 24.09.2011
Сообщений: 1,274
18.10.2016, 10:31
Invader0x7F, мне кажется, что у Вас где-то ошибка. На эти мысли меня наводят строки и столбцы, целиком состоящие из нулей. А ведь чётная сумма индексов будет только у ~50% этих элементов.
1
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
18.10.2016, 10:48
Вот пример который хорошо иллюстрирует выполнение соответствующих операций согласно условию. Других вариантов у меня нет:
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;
 
int main() 
{
    const int N = 20;
    int A[N][N] = { { 0 } };
 
    for (int row = 0; row < N; row++)
    {
        int n = 0;
        for (int col = 0; col < N; col++)
        {
            A[row][col] = n++; //std::rand() % 9 + 1;
            std::cout << A[row][col] << " ";
        }
 
        std::cout << endl;
    }
 
    std::cout << endl;
 
    for (int row = 0; row < N; row++)
        for (int col = 0; col < N; col++)
            if (((row + col) % 2) == 0)
            {
                bool found = false;
                int r_fwd = 0, c_fwd = 0;
                while (r_fwd < N && !found)
                {
                    if (c_fwd >= N) { c_fwd = 0; r_fwd++; }
                    if (A[r_fwd][c_fwd] == A[row][col])
                        found = true;
 
                    c_fwd++;
                }
            
                if (found == true) A[row][col] = 0;
            }
 
    for (int row = 0; row < N; row++)
    {
         for (int col = 0; col < N; col++)
              std::cout << A[row][col] << " ";
         
         std::cout << endl;
    }
 
    std::cout << endl << endl;
 
    std::cin.get();
}
Миниатюры
Заменить нулями в матрице элементы с чётной суммой индексов  
2
Объявлятель переменных
 Аватар для SpBerkut
1220 / 406 / 320
Регистрация: 24.09.2011
Сообщений: 1,274
18.10.2016, 10:55
Кусок кода, заменяющий элементы матрицы M ранга n с чётной суммой индексов, входящие в состав вектора A размерностью 10.
C++
1
2
3
4
5
6
7
8
9
10
for (unsigned i = 0; i < n; i++) {
    for (unsigned j = i%2; j < n; j+=2) { // т.к. нам нужна чётная сумма индексов, перебираем лишь нужную половину
        for (unsigned k = 0; k < 10; k++) {
            if (M[i][j] == A[k]) {
                M[i][j] = 0;
                break;
            }
        }
    }
}
Весь код:
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
#include <iostream>
#include <cstdlib>
#include <ctime>
 
int main()
{
    // ну, это понятно
    srand(time(0));
    
    // объявление, формирование и вывод вектора А
    unsigned A[10];
    for (unsigned i = 0; i < 10; i++) {
        A[i] = 10 + rand()%90;
        std::cout << A[i] << ' ';
    }
    std::cout << std::endl << std::endl;
    
    // объявление и ввод ранга матрицы М
    unsigned n;
    std::cout << "\nn: "; std::cin >> n;
    
    // Объявление матрицы М
    unsigned M[n][n];
    
    // формирование и вывод матрицы M
    for (unsigned i = 0; i < n; i++) {
        for (unsigned j = 0; j < n; j++) {
            M[i][j] = 10 + rand()%90;
            std::cout << M[i][j] << ' ';
        }
        std::cout << std::endl;
    }
    
    // замена элементов матрицы М с чётными индексами на 0 согласно условия
    for (unsigned i = 0; i < n; i++) {
        for (unsigned j = i%2; j < n; j+=2) {
            for (unsigned k = 0; k < 10; k++) {
                if (M[i][j] == A[k]) {
                    M[i][j] = 0;
                    break;
                }
            }
        }
    }
    
    std::cout << std::endl << std::endl;
    
    // вывод матрицы М
    for (unsigned i = 0; i < n; i++) {
        for (unsigned j = 0; j < n; j++) {
            std::cout << M[i][j] << ' ';
        }
        std::cout << std::endl;
    }
}
1
Helper C/C++
 Аватар для Invader0x7F
286 / 163 / 122
Регистрация: 22.09.2016
Сообщений: 518
18.10.2016, 13:55
SpBerkut, мой код, который я выложил (без оптимизации) особенно пригодится если необходимо заменять элементы с индексами row и col, чья, например, полу-сумма или полу-произведение является четным.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.10.2016, 13:55
Помогаю со студенческими работами здесь

C++ Дана квадратная матрица. заменить нулями элементы с четной суммой индексов
C++ Дана квадратная матрица. заменить нулями элементы с четной суммой индексов программа рабочая, но нужно сделать с помощью функций . ...

Как осуществить замену нулями в матрице тех элементов с четной суммой индексов,для которых имеются равные среди a1,.a10
Даны целые числа a1, ... ,a10, целочисленная квадратная матрица порядка n. Заменить нулями в матрице те элементы с четной суммой индексов,...

Заменить нулями в матрице элементы с четной суммой индексов
1. Даны целые числа а1,...,а4 и целочисленная матрица А(4х4). Заменить нулями в матрице элементы с четной суммой индексов, равные...

Заменить нулями в матрице элементы с четной суммой индексов
Даны массив А=(a1, a2, ..., a10) и матрица B. Заменить нулями в матрице те элементы с четной суммой индексов, для которых имеются равные...

Заменить нулями в матрице те элементы с чётной суммой индексов...
Даны целые числа а1,...,а10, целочисленная матрица n.Заменить нулями в матрице те элементы с чётной суммой индексов для которых имеются...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Вопросы на собеседованиях по микросервисам
ArchitectMsa 27.03.2025
Работодатели ищут не просто разработчиков, знающих базовые концепции, а специалистов, разбирающихся в тонкостях масштабирования, отказоустойчивости и производительности. Сейчас на первый план выходят. . .
Взаимодействие Python с REST API
py-thonny 27.03.2025
REST API - это архитектурный стиль взаимодействия компонентов распределённого приложения в сети. Python располагает функциональным набором инструментов для работы с REST API и основная библиотека для. . .
sshd restrictions, ssh access limitations
jigi33 26.03.2025
sshd restrictions | ssh access limitations рестрикции доступа на сервер sshd статья: https:/ / www. golinuxcloud. com/ restrict-allow-ssh-certain-users-groups-rhel
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru