Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
J_Max
Заблокирован
#1

Перестановка строк матрицы - C++

29.03.2010, 12:36. Просмотров 834. Ответов 1
Метки нет (Все метки)

Прошу прощения если такая тема есть, поиск не помог мне её найти.
Дана матрица MxN:
Переставить строки матрицы по возрастанию максимальных элементов строк.
То есть:
9 8 7
6 5 4
3 2 1

Будет так:
3 2 1
6 5 4
9 8 7

Надеюсь на вашу помощь.
Заранее спасибо...
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.03.2010, 12:36     Перестановка строк матрицы
Посмотрите здесь:

Перестановка строк матрицы - C++
Дана матрица размером М:N,найти матрицу полученную из данной перестановкой строк 1ой строки с последней.2 ой с предпоследней и т.д.(матрица...

Перестановка строк матрицы - C++
Ребята помогите, если не сложно! Накипело задачку решить, а в С++ баран) Вот задание: Переставить строки матрицы в соответствии с...

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

Перестановка местами строк матрицы - C++
Задано двухмерный массив (матрицу) А размером n*m. Целые числа m и n (в ввиде констант) и елементы масива (действительные числа) задать...

Перестановка местами строк и столбцов матрицы - C++
Помогите решить задачу: Дана матрица А(nxm).Получить матрицу, получающуюся из данной : перестановкой строк- первой с последней, второй с...

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

Перестановка строк в массиве - C++
Здравствуйте, не могу никак сообразить, как сделать свою задачу: Необходимо переставить строки в матрице. Пример: Исходная матрица: ...

Перестановка строк со столбцами - C++
Здравствуйте форумчане! у меня вот такая вот задачка: Написать процедуру обмена столбца и строки двухмерного массива. С ее помощью...

Перестановка строк в матрице (С++) - C++
Здравствуйте ребята,очень нужна помощь помогите пожалуйста написать программу.. смысл в том что в программе я должна ввести любую...

Перестановка строк в матрице - C++
Добрый день Дана заданная целочисленная матрица 6x9. Нужно чтобы по заданному пользователем распорядку чисел от 1 до 9 выстаивались в...

Перестановка строк в матрице - C++
Дана целочисленная матрица размера 6х9. Найти матрицу, получающуюся из данной: перестановкой строк первой с последней, второй с...

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


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
mirso
525 / 343 / 17
Регистрация: 05.04.2009
Сообщений: 709
29.03.2010, 15:51     Перестановка строк матрицы #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
J_Max,
Цитата Сообщение от J_Max Посмотреть сообщение
Переставить строки матрицы по возрастанию максимальных элементов строк.
можно с помощью дополнительного массива max_arr[M]
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
#include <iostream>
 
int main()//=========================================================
{
    const int M = 3;
    const int N = 3;
    int arr[M][N] = { { 9, 8, 7 },
                      { 6, 5, 4 },
                      { 3, 2, 1 } };
 
    int max_arr[M] = { 0 };
    //------------------------------------
    for ( int i = 0; i < M; ++i )
    {
        max_arr[i] = arr[i][0];
        for ( int j = 1; j < N; ++j )
        if ( arr[i][j] > max_arr[i] )
        {
            max_arr[i] = arr[i][j]; 
        }
    }
    //------------------------------------
    for ( int i =     0; i < M - 1; ++i )
    for ( int j = i + 1; j < M    ; ++j )
    {       
        if ( max_arr[i] > max_arr[j] )
    {
          int t = max_arr[i];
          max_arr[i] = max_arr[j];
          max_arr[j] = t;
 
          for ( int k = 0; k < N; ++k )
          {
            t = arr[i][k];
            arr[i][k] = arr[j][k];
            arr[j][k] = t;
          }
    }
    }
    //------------------------------------
    for ( int i = 0; i < M; ++i )
    for ( int j = 0; j < N; ++j )
    {
        std::cout << arr[i][j] << ' ';
        if ( j == N - 1 )
        std::cout << std::endl;
    }
 
    return 0;
}//==================================================================
Ответ Создать тему
Опции темы

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