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

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

24.03.2019, 16:26. Показов 716. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать программу, которая создаст матрицу A[n][2n] и ПОСЛЕДОВАТЕЛЬНО изменит все окруженные положительными числами числа на разность минимального и максимального из их окружения. Работать с боковыми числами не надо(т.е. начинаем с i=2 и j=2 а заканчиваем i=n-1 и j=n-1)
Пример:
12 23 54 56 32 98
42 43 31 35 31 98
53 75 24 74 42 90

тут число 43 окружено положительными числами, значит заменим его на -63 (12-75). Тогда мы пропустим число 31(оно правее 43) так как 43 мы уже заменили на -63(отрицательное) и идем к следующему, т.е. к 35. его тоже заменяем на разность (24-74)
В итоге получаем матрицу
12 23 54 56 32 98
42 -63 31 35 -50 98
53 75 24 74 42 90
проблема в строке if ((m[i-1][j-1] && m[i-1][j] && m[i-1][j+1] && m[i][j-1] ...
выдает, что: Необработанное исключение в "0x0138113d" в "zadanie.exe": 0xC0000005: Нарушение прав доступа при чтении "0x002b0000".
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
void main()
{
    const int n=3;
    int a=0;
    int m[n][2*n];
    int i, j;
    for (i=0;i<n;i++)
    {
 
        for (j=0;j<2*n; j++)
        {
            m[i][j]=(rand() % 100)-50;
            cout<<m[i][j]<<"\t";
        }
    cout<<endl;
    }
cout<<endl;
 
    for (i=1;i<n-1; i++)
    {
        for (j=1;i<(2*n)-1; j++)
        {
            if ((m[i-1][j-1] && m[i-1][j] && m[i-1][j+1] && m[i][j-1] && m[i][j+1] && m[i+1][j-1] && m[i+1][j] && m[i+1][j+1])>0)
            {
                int max=m[i-1][j-1];
                int min=m[i-1][j-1];
                for (int im=i-1;im<i+1;im++)
                {
                    for (int jm=j-1;jm<j+1;jm++)
                    {
                        if (m[im][jm]>max) max=m[im][jm];
                        if (m[im][jm]<min) min=m[im][jm];
                    }
                }
            m[i][j]=min-max;
            }
        }
    }
    for (i=0;i<n;i++)
    {
 
        for (j=0;j<2*n; j++)
        {
            m[i][j]=(rand() % 100)-50;
            cout<<m[i][j]<<"\t";
        }
    cout<<endl;
    }
cout<<endl;
system("pause");
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.03.2019, 16:26
Ответы с готовыми решениями:

Вычислить разность максимального и минимального элементов в матрице
Есть этот код. Он вычесляет разность максимального и минимального елементов в матрице. Как сделать так что бы он делал тоже самое но в...

Найти все нули, окруженные единицами, в матрице
нужно найти все нули в матрице покрытые вокруг единицами: вот написал, но не чего не выдает, подскажите что неправильно #include...

В матрице все элементы, модули которых равны модулям максимального или минимального элемента, заменить значением y
В матрице все элементы, модули которых равны модулям максмального или минимального элемента, заменить значением y. y=10; v= Как...

7
 Аватар для Krokodil9798
330 / 145 / 56
Регистрация: 17.10.2015
Сообщений: 580
24.03.2019, 17:13
Цитата Сообщение от artemor3228 Посмотреть сообщение
C++
1
for (j=1;i<(2*n)-1; j++)
Да это же очепятка (строка 21)
Для прохода по столбцам используется переменная j, но для проверки критерия завершения цикла - i.
Вывод: копипаст частей своего кода, с целью избежания расхода времени на его напечатание - дело рук только профи, не повторяйте в домашних условиях, это может быть опасно для жизни...
0
0 / 0 / 0
Регистрация: 22.01.2019
Сообщений: 57
24.03.2019, 17:55  [ТС]
Опечатку исправил, но код работает не правильно, в чем тут может быть ошибка?
0
Модератор
Эксперт С++
 Аватар для zss
13769 / 10962 / 6491
Регистрация: 18.12.2011
Сообщений: 29,238
24.03.2019, 18:29
1.
Цитата Сообщение от artemor3228 Посмотреть сообщение
for (j=1;i<(2*n)-1; j++)
for (j=1;j<(2*n)-1; j++

2. 44 строка не нужна.
Вот эта
Цитата Сообщение от artemor3228 Посмотреть сообщение
m[i][j]=(rand() % 100)-50;
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
24.03.2019, 18:33
Цитата Сообщение от artemor3228 Посмотреть сообщение
if ((m[i-1][j-1] && m[i-1][j] && m[i-1][j+1] && m[i][j-1] && m[i][j+1] && m[i+1][j-1] && m[i+1][j] && m[i+1][j+1])>0)
логическое И работает немного по другому принципу
0
0 / 0 / 0
Регистрация: 22.01.2019
Сообщений: 57
24.03.2019, 18:54  [ТС]
а как тогда оформить эту строку?
if ((m[i-1][j-1] && m[i-1][j] && m[i-1][j+1] && m[i][j-1] && m[i][j+1] && m[i+1][j-1] && m[i+1][j] && m[i+1][j+1])>0)
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
24.03.2019, 19:15
Цитата Сообщение от artemor3228 Посмотреть сообщение
а как тогда оформить эту строку?
нужно каждый элемент сравнивать с 0
0
 Аватар для Krokodil9798
330 / 145 / 56
Регистрация: 17.10.2015
Сообщений: 580
24.03.2019, 19:40
Цитата Сообщение от artemor3228 Посмотреть сообщение
а как тогда оформить эту строку?
C++
1
2
3
4
5
6
7
8
9
10
11
if 
(
    m[i-1][j-1] > 0 && 
    m[i-1][j] > 0 && 
    m[i-1][j+1] > 0 && 
    m[i][j-1] > 0 && 
    m[i][j+1] > 0 && 
    m[i+1][j-1] > 0 && 
    m[i+1][j] > 0 && 
    m[i+1][j+1]) > 0
)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.03.2019, 19:40
Помогаю со студенческими работами здесь

разность максимального и минимального элемента матрицы
Если разность максимального и минимального элемента матрицы А превышает заданную величину Р, заменить в матрице А все отрицательные...

Найти разность максимального и минимального элементов в массивах С(14) и Т(8)
Используя подпрограммы-процедуры и подпрограммы функции ,составить блок-схему и программу для решения задачи. Задача : Найти...

Вычислить разность максимального и минимального элементов массива.
Написать программу, которая вычисляет разность максимального и минимального элементов массива. Массив и его длина вводятся...

Найти разность максимального и минимального элементов массива
Ребята help!!! Нужно решить следующую задачу: Создать масив 12 на 12 с именем а. Найти разность максимальное max-min. действительные...

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


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru