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

Поиск максимального значения матрицы,замена элементов - C++

Восстановить пароль Регистрация
 
RandomNikname
1 / 1 / 0
Регистрация: 24.10.2010
Сообщений: 5
14.11.2010, 15:49     Поиск максимального значения матрицы,замена элементов #1
Необходимо найти максимальный элемент матрицы и поменять его с последним.
Вот что у меня получилось:
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
#include <iostream.h>
#include <conio.h>
void main()
{
int **a, i, j, n, m,x,k,l,tmp;
cout << "\t Input N, M : ";
cin >> n >> m;
a = new int*[n];                    
for(i=0; i<n;i++)
a[i] = new int[m];  
cout <<"\n Input A" << endl;
for(i=0; i<n; i++)
                for(j=0; j<m; j++){
                        cout << "\t a[" << i << "][" << j << "] = ";
                        cin >> a[i][j];
                }
cout <<"\n Matrix A:" << endl;
for(i=0; i<n; i++) {
                for(j=0; j<m; j++)
                cout << "\t" << a[i][j];
                cout << endl;
                
}
cout<<"New Matrix: "<<endl;
x=a[0][0];
for(i=0;i<n;i++) {                             
                for(j=0;j<m;j++){ 
                    if(a[i][j]>x){             //находим максимальный элемент
                        x=a[i][j];
                        k=i;
                        l=j;
                    }
                }
                            
                    
}
cout << "max=" << a[k][l] << endl;
for(i=0;i<n;i++){                             
    for(j=0;j<m;j++){
        tmp=a[n-1][m-1];                      //меняем местами максимальный элемент и последний
        a[n-1][m-1]=a[k][l];
        a[k][l]=tmp;
    cout << "\t" << a[i][j];
    }
    cout<<endl;
}
delete []a; 
getch();
}
В итоге, в зависимости от размерности матрицы и расстановки значений,либо перестановка не выполняется,либо оба элемента заменяются максимальным,либо оба заменяются последним.

Добавлено через 48 минут
Все, разобрался, надо было вынести строки 40-42 перед циклом
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.11.2010, 15:49     Поиск максимального значения матрицы,замена элементов
Посмотрите здесь:

C++ Поиск максимального значения функции на заданном промежутке
C++ Поиск и замена максимального элемента двумерного массива
Массивы, вложенные циклы и поиск максимального и минимального значения C++
C++ Поиск максимального значения в списке.
Найти сумму максимального значения элементов с четными индексами и минимального значения элементов с нечетными индексами в одномерном массиве C++
C++ Поиск максимального и минимального значения в матрице
Двумерный массив, сравнение, поиск максимального, замена C++
Замена максимального и минимального элементов прямоугольной матрицы их средним геометрическим C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
14.11.2010, 17:11     Поиск максимального значения матрицы,замена элементов #2
Все, разобрался, надо было вынести строки 40-42 перед циклом
и не только это. если максимальный элемент будет a[0][0], то у Вас будет ошибка.
Yandex
Объявления
14.11.2010, 17:11     Поиск максимального значения матрицы,замена элементов
Ответ Создать тему
Опции темы

Текущее время: 01:33. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru