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

Программа по поиску наименьшего по модулю элемента матрицы не работает корректно

31.01.2018, 20:02. Показов 1069. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание: Составить алгоритм обработки матрицы А типа short размером М х N (М≤10 строк, N≤10 столбцов). Значения М и N ввести с клавиатуры. Получить новую матрицу путем вычитания всех элементов данной матрицы из ее наименьшего по модулю элемента.
Проблема заключается в поиске наименьшего по модулю элемента - алгоритм по неведомым мне причинам работает не всегда (функция min_el). Если же ищу наибольший элемент - все работает корректно.

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
#include <iostream>
#include <math.h>
#include <time.h>
#define SIZE 10
using namespace std;
void user_matrix(short A[][SIZE], short r, short c);
void rand_matrix(short A[][SIZE], short r, short c);
void output(short A[][SIZE], short r, short c);
short min_el(short A[][SIZE], short r, short c);
void new_matrix(short A[][SIZE], short r, short c, short min);
 
short main() {
    short A[SIZE][SIZE], r, c, choice;
    cout << "input row"<< endl;
    cin >> r;
    cout << "input col"<< endl;
    cin >> c;
    cout << "1 - by user, 2 - by random" << endl;
    cin >> choice;
    switch (choice) {
    case 1: user_matrix(A, r, c);
    case 2: rand_matrix(A, r, c);
    }
    output(A, r, c);
    short min = min_el(A, r, c);
    //cout << "min el =" << min << endl;
    cout << min_el(A, r, c) << endl;
    cout << "new matrix" << endl;
    new_matrix(A, r, c, min_el(A,r,c) );
    return 0;
}
 
void user_matrix(short A[][SIZE], short r, short c) {
    for (short i = 0; i < r; i++) 
        for (short j = 0; j < c; j++) 
            cin >> A[i][j];
    return;
}
 
void rand_matrix(short A[][SIZE], short r, short c) {
    srand((unsigned)time(NULL));
    for (int i = 0; i<r; i++)
        for (int j = 0; j<c; j++)
            A[i][j] = rand() % (r*c) - rand() % (r*c);
    return;
 
}
 
void output(short A[][SIZE], short r, short c) {
    for (short i = 0; i < r; i++) {
        for (short j = 0; j < c; j++)
            cout << A[i][j] << '\t';
        cout << endl;
    }
    return;
}
 
short min_el(short A[][SIZE], short r, short c) {
    short min = A[0][0];
    for (short i = 0; i < r; i++) {
        for (short j = 0; j < c; j++) {
            if (fabs(A[i][j]) < min) min= fabs(A[i][j]);
        }
    }
    return min;
}
 
void new_matrix(short A[][SIZE], short r, short c, short min) {
    short element = min;
    for (short i = 0; i < r; i++)
        for (short j = 0; j < c; j++)
            element = element - A[i][j];
    for (short i = 0; i < r; i++) {
        for (short j = 0; j < c; j++)
            cout << element << '\t';
        cout << endl;
    }
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
31.01.2018, 20:02
Ответы с готовыми решениями:

Напечатать значение наименьшего по модулю элемента матрицы и его индексы
Не понимаю как решить задачу: В массиве А(mxn) найти элемент являющийся наименьшим по модулю. Напечатать значение этого элемента и его...

Вывести на экран произведение наименьшего по модулю отрицательного и наименьшего положительного элемента
Организовать ввод последовательности из N чисел и получить и вывести на экран произведение наименьшего по модулю отрицательного элемента и...

Получите новую матрицу путем вычитания из всех элементов данной матрицы наименьшего по модулю элемента
Дана вещественная матрица размером 4 строки, 5 столбцов. Получите новую матрицу путем вычитания из всех элементов данной матрицы наименьшую...

3
 Аватар для Herji
299 / 208 / 174
Регистрация: 11.05.2016
Сообщений: 655
31.01.2018, 20:22
Лучший ответ Сообщение было отмечено danielq как решение

Решение

Цитата Сообщение от danielq Посмотреть сообщение
C++
1
short min = A[0][0];
может таки для начала
C++
1
short min = fabs(A[0][0]);
1
 Аватар для Hitoku
1755 / 1347 / 1407
Регистрация: 28.10.2016
Сообщений: 4,267
31.01.2018, 20:24
Herji, можно оставить как было (всё таки минимальное значение должно храниться не в виде модуля, а в виде самого числа) и при проверке брать модуль переменной min
1
 Аватар для Herji
299 / 208 / 174
Регистрация: 11.05.2016
Сообщений: 655
31.01.2018, 20:33
Цитата Сообщение от Hitoku Посмотреть сообщение
можно оставить как было (всё таки минимальное значение должно храниться не в виде модуля, а в виде самого числа) и при проверке брать модуль переменной min
Вот это
Цитата Сообщение от danielq Посмотреть сообщение
C++
1
2
3
4
min= fabs(A[i][j]);
        }
    }
    return min;
и так ломает весь смысл, а лишнюю сотню раз fabs() брать тоже не комильфо;
тут, если попроще, можно индексы хранить

Добавлено через 2 минуты
Hitoku, А, вообще дошло в чем смысл предложения)

Добавлено через 2 минуты
C++
1
2
3
4
5
6
7
    short min = A[0][0];
    for (short i = 0; i < r; i++) {
        for (short j = 0; j < c; j++) {
            if (fabs(A[i][j]) < fabs(min)) min= A[i][j];
        }
    }
    return min;
так оно, да, логичнее
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.01.2018, 20:33
Помогаю со студенческими работами здесь

Cреднее арифметическое наименьшего по модулю и наибольшего по модулю элементов матрицы
Здравствуйте, помогите пожалуйста решить задачe, нужно до 5-го числа сдать. Дана действительная матрица размера m на n. Найти среднее...

Не корректно работает программа (Упорядочить элементы матрицы)
Условие: Дана матрица целых чисел N* M.Упорядочить элементы матрицы так чтобы четные элементы матрицы максимально плотно заняли верхнюю...

Нахождение наименьшего по модулю элемента массива в С++
Вот мой код :#include &lt;iostream&gt; #include&lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;cmath&gt; using namespace std; int main(){ const...

Сумма модулей элементов массива, после наименьшего по модулю элемента
Добрый день. Возникла проблема с решением задачки. Суть в том что в массиве нужно определить наименьший элемент по модулю и после этого...

подскажите как вывести индекс наименьшего по модулю элемента в массиве
вот фрагмент программы var e:array of integer; i,min,count,ind: integer; begin for i:=1 to 10 do begin randomize; ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru