Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Illia1551
0 / 0 / 0
Регистрация: 22.04.2018
Сообщений: 26
1

Найти в каждой строке максимальный и минимальный элементы и поменять их местами с первым и последним элементом

12.12.2018, 09:21. Просмотров 340. Ответов 1
Метки нет (Все метки)

3. Дана матрица B размерностью n×m. Найти в каждой строке матрицы максимальный и минимальный элементы и поменять их местами с первым и последним элементом строки соответственно.
Буду благодарен за помощь
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.12.2018, 09:21
Ответы с готовыми решениями:

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

Найти максимальный и минимальный элемент в каждой строке массива и поменять местами с первым и последним элементом
Дана матрица M*N. Нужно найти максимальный и минимальный элемент в каждой строке массива и поменять...

Найти в каждой строке матрицы максимальный и минимальный элементы и поменять их местами с первым и последним
Дана матрица B. Найти в каждой строке матрицы максимальный и минимальный элементы и поменять их...

Поменять местами максимальный элемент матрицы с его первым элементом а минимальный с последним
ДВУМЕРНЫЙ МАССИВ: Поменять местами максимальный элемент матрицы F(k,p)в его первым элементом, а...

Поменять местами минимальный элемент с первым элементом массива, а максимальный элемент с последним
Здравствуйте. Помогите пожалуйста написать программу: для поиска минимального и максимального...

1
serggg
58 / 42 / 23
Регистрация: 24.03.2013
Сообщений: 1,093
Завершенные тесты: 1
12.12.2018, 10:58 2
Вот как-то так решил эту задачу:
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
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "");
    int n = 0, m = 0, indexMaxElem = 0, maxElem = 0, indexMinElem = 0, minElem = 0, tmpElem = 0;
    cout << "Введите число строк в массиве\n";
    cin >> n;
    cout << "Введите число столбцов в массиве\n";
    cin >> m;
    int **myArray = new int*[n];    // динамически выделяем память под строки массив
    srand(time(NULL));
    for (int i = 0; i < n; i++)
    {
        myArray[i] = new int[m];    
        for (int j = 0; j < m; j++)
            myArray[i][j] = rand() % 100 - 50;  // заполняем массив случайными числами
    }
 
    cout << "Сгенерированный массив\n";
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
            cout << myArray[i][j] << "\t";  // выводим элементы массива в консоль
        cout << "\n";
 
    }
 
    for (int i = 0; i < n; i++) // перебираем каждую строку массива
    {
        indexMaxElem = 0;   // задаём начальные значения максимального элемента, как значения первого элемента строки
        maxElem = myArray[i][indexMaxElem];
 
        indexMinElem = m-1; // задаём начальные значения минимального элемента, как значения последнего элемента строки 
        minElem = myArray[i][indexMinElem];
 
        for (int j = 0; j < m; j++) // перебираем элементы строки
        {
            if (myArray[i][j] <= minElem)   // если очередной элемент меньше или равен
            {
                indexMinElem = j;   // нашли новый минимум, сохраняем его индекс в строке
                minElem = myArray[i][indexMinElem]; // сохраняем новый минимальный элемент
            }
 
            if (myArray[i][j] >= maxElem)   // если очередной элемент больше или равен 
            {
                indexMaxElem = j;   // нашли новый максимум, сохраняем его индекс в строке
                maxElem = myArray[i][indexMaxElem]; // сохраняем новый максимальный элемент
            }
        }
        
        // после того, как прошли всю строку
        // меняем меcтами максимальный элемент с первым элементом строки
        tmpElem = myArray[i][0];
        myArray[i][0] = myArray[i][indexMaxElem];
        myArray[i][indexMaxElem] = tmpElem;
               
        // меняем местами минимальный элемент с последним элементом строки
        tmpElem = myArray[i][m - 1];
        myArray[i][m - 1] = myArray[i][indexMinElem];
        myArray[i][indexMinElem] = tmpElem;
 
    }
 
    cout << "\nОбработанный массив\n";
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
            cout << myArray[i][j] << "\t";  // выводим элементы массива в консоль
        cout << "\n";
 
    }
 
    system("pause");
}
Если нужно, можно дописать ручной (или из файла) ввод массива чисел.
0
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.12.2018, 10:58

В каждой строке матрицы поменять местами максимальный и минимальный элементы
Дана действительная матрица размера (nxm), (n,m меньше или равно 10). В каждой строке матрицы ...

В произвольной матрице поменять местами в каждой строке минимальный и максимальный элементы
Доброго времени суток господа! Помогите закончить программу, условие таково: В произвольной...

В произвольной матрице A [ N ][ M ] поменять местами в каждой строке минимальный и максимальный элементы
Здраствуйте,помогите пожалуйста с кодом для данной задачи: В произвольной матрице A поменять...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru