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

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

Войти
Регистрация
Восстановить пароль
 
nazerke-m-95
2 / 2 / 0
Регистрация: 24.11.2013
Сообщений: 43
#1

Дана матрица размера 6x9. Поменять местами строки содержащие минимальный и максимальный элемент - C++

24.04.2014, 20:12. Просмотров 1268. Ответов 4
Метки нет (Все метки)

дана матрица размера 6x9 поменять местами строки содержащие минимальный и максимальный элемент (такие элементы должны быть одни) ))) спасибо заранее!!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.04.2014, 20:12
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Дана матрица размера 6x9. Поменять местами строки содержащие минимальный и максимальный элемент (C++):

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

Дана матрица размера 5*10, преобразовать матрицу, поменяв местами минимальный и максимальный элемент в каждой строке. C++ - C++
Есть код программы...но она меняет тока в 1й строке остальные нет((( Прошу помочь...Заранее спасибо откликнувшимся #include...

Дана матрица,поменять местами строки те,в которых расположен миним. и максимальный элемент массива - C++
Пожалуйста)

Дана матрица размера M на N.Поменять местамистолбцы,содержащие минимальный и максимальные элементы матрицы. - C++
Дана матрица размера M на N.Поменять местамистолбцы,содержащие минимальный и максимальные элементы матрицы.

Поменять местами строки, содержащие минимальный и максимальный элементы матрицы - C++
Дана матрица размера 5х10. Поменять местами строки, содержащие минимальный и максимальный элементы матрицы.

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

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
kmaffa
275 / 271 / 44
Регистрация: 29.10.2012
Сообщений: 716
24.04.2014, 20:34 #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
static void Main(string[] args)
{
    int[,] a = new int[6, 9];
    int index = 10;
    int[] a0 = new int[a.Length];
    for (int i = 0; i < a.Length; i++)
        a0[i] = index++;
    a0 = a0.OrderBy(e => Guid.NewGuid()).ToArray();
    index = 0;
    for (int i = 0; i < a.GetLength(0); i++)
        for (int j = 0; j < a.GetLength(1); j++)
            a[i, j] = a0[index++];
    Print(a);
    int max = int.MinValue,
        min = int.MaxValue;
    int i_min = 0, j_min = 0, i_max = 0, j_max = 0;
    for (int i = 0; i < a.GetLength(0); i++)
        for (int j = 0; j < a.GetLength(1); j++)
        {
            if (min > a[i, j])
            {
                min = a[i, j];
                i_min = i;
                j_min = j;
            }
            if (max < a[i, j])
            {
                max = a[i, j];
                i_max = i;
                j_max = j;
            }
        }
    a[i_min, j_min] = max;
    a[i_max, j_max] = min;
    Console.WriteLine("\n\n");
    Print(a);
 
    Console.ReadKey();
 
}
static void Print(int[,] a)
{
    for (int i = 0; i < a.GetLength(0); i++)
    {
        for (int j = 0; j < a.GetLength(1); j++)
        {
            Console.Write("{0} ", a[i, j]);
        }
        Console.WriteLine();
    }
}
nazerke-m-95
2 / 2 / 0
Регистрация: 24.11.2013
Сообщений: 43
24.04.2014, 20:56  [ТС] #3
поменять местами нужно строку а не элемент. Можете написать??

Добавлено через 18 минут
мне нужно срочно буду очень благодарно

 Комментарий модератора 
Дублирование тем запрещено
kmaffa
275 / 271 / 44
Регистрация: 29.10.2012
Сообщений: 716
24.04.2014, 21:03 #4
Вместо 33 и 34 строки вставьте вот этот код:
C#
1
2
3
4
5
6
for (int j = 0; j < a.GetLength(1); j++)
{
    int t = a[i_min, j];
    a[i_min, j] = a[i_max, j];
    a[i_max, j] = t;
}
Весь код
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
static void Main(string[] args)
{
    int[,] a = new int[6, 9];
    int index = 10;
    int[] a0 = new int[a.Length];
    for (int i = 0; i < a.Length; i++)
        a0[i] = index++;
    a0 = a0.OrderBy(e => Guid.NewGuid()).ToArray();
    index = 0;
    for (int i = 0; i < a.GetLength(0); i++)
        for (int j = 0; j < a.GetLength(1); j++)
            a[i, j] = a0[index++];
    Print(a);
    int max = int.MinValue,
        min = int.MaxValue;
    int i_min = 0, i_max = 0;
    for (int i = 0; i < a.GetLength(0); i++)
        for (int j = 0; j < a.GetLength(1); j++)
        {
            if (min > a[i, j])
            {
                min = a[i, j];
                i_min = i;
            }
            if (max < a[i, j])
            {
                max = a[i, j];
                i_max = i;
            }
        }
    for (int j = 0; j < a.GetLength(1); j++)
    {
        int t = a[i_min, j];
        a[i_min, j] = a[i_max, j];
        a[i_max, j] = t;
    }
    Console.WriteLine("\n\n");
    Print(a);
    Console.ReadLine();
}
static void Print(int[,] a)
{
    for (int i = 0; i < a.GetLength(0); i++)
    {
        for (int j = 0; j < a.GetLength(1); j++)
        {
            Console.Write("{0} ", a[i, j]);
        }
        Console.WriteLine();
    }
}
bradobrei
Продам уран 238U
119 / 119 / 23
Регистрация: 22.01.2013
Сообщений: 298
25.04.2014, 08:04 #5
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
#define n 5
#define m 9
int main(){
    srand(time(NULL)); 
    int mas[n][n], min = 9999, max = -9999;
    int minstr = 0, maxstr = 0, tmp = 0;
    cout << "In:" << endl;
    for(int i = 0; i < n; i++){
        for(int j = 0; j < n; j++){
            mas[i][j] = rand()% 100 - 10;
            cout << mas[i][j] << " ";
            if(mas[i][j] > max){
                max = mas[i][j];
                maxstr = i;
            }
            if(mas[i][j] < min){
                min = mas[i][j];
                minstr = i;
            }
        }
    cout << endl;
    }
    cout << endl << "Max = " << max << " maxstr = " << maxstr + 1 << endl << "Min = " << min << " minstr = " << minstr + 1 << endl << "Out: " << endl;
    if(maxstr != minstr){
    for(int i = 0; i < m; i++){
        tmp = mas[maxstr][i];
        mas[maxstr][i] = mas[minstr][i];
        mas[minstr][i] = tmp;
    }
    }
    for(int i = 0; i < n; i++){
        for(int j = 0; j < n; j++){
            cout << mas[i][j] << " ";
        }
    cout << endl;
    }
return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.04.2014, 08:04
Привет! Вот еще темы с ответами:

Матрица, найти и поменять местами минимальный и максимальный элемент - C++
Помогите с задачей: В квадратной матрице A найти среди элементов, расположенных ниже главной диагонали, минимальный элемент, а среди...

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

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

дана матрица А(5,5). Каждый минимальный элемент строки поменять на максимальное значение элемента, побочной диагонали - C++
дана матрица А(5,5). Каждый минимальный элемент строки поменять на максимальное значение элемента, побочной диагонали.


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
25.04.2014, 08:04
Ответ Создать тему
Опции темы

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