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

В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0 - C++

Восстановить пароль Регистрация
 
Stastriada95
Сообщений: n/a
28.05.2013, 12:47     В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0 #1
Доброго времени дня! Очень большая прозьба помочь с задачей по C++.
Задание: В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0.
Сам я смог написать (не без помощи интернета конечно же) только программу, которая ищит максимум во всей матрице. Я перепробовал все что знал, чтобы посчитать максимум выше побочной, но никак. Помогите пожалуйста дописать программу или как то по другому (советом например). Зарание спасибо!
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
#include <iostream>
#include <math.h>
#include <conio.h>
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
using namespace std;
int main()
{setlocale(0,"");
double **a,*p,h;
int n,m=6,i,j,k;
cout << "Находим максимальный элемент матрицы"<< endl;
cout << "--------------------------------------"<< endl;
 
n=m;
 
a=new double *[n];
for(i=0;i<n;i++)
a[i]=new double[m];
for(i=0;i<n;i++)
for(j=0;j<m;j++)
a[i][j]=rand()%1000;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
cout<<a[i][j]<<"   |   ";
cout<<endl;
}
 
double l=fabs(a[0][0]);
int s=0,t=0;
for(i=0;i<n;i++)
for(j=0;j<m;j++)
if(fabs(a[i][j])>l)
{
l=fabs(a[i][j]);
t=i;
s=j;
}
cout <<"Максимальный эллемент =  ";
cout <<l<<endl;
cout<<" "<<endl;
 
for(i=0;i<n;i++)
delete [] a[i];
delete [] a;
}
программная среда Code::Blocks 10.05
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.05.2013, 12:47     В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0
Посмотрите здесь:

C++ В квадратной матрице найти максимальный среди элементов, лежащих ниже побочной диагонали.
C++ Заменить в матрице элементы побочной диагонали значениями сумм элементов соответствующих строк
C++ В двумерном массиве размерностью nxm найти сумму элементов, стоящих на побочной диагонали.
Найти минимальный из элементов ниже главной и выше побочной диагонали и поменять его местами с первым элементом матрицы C++
C++ Найти максимальный элемент матрицы расположенный выше побочной диагонали и его местоположение
Заменить элементы главной диагонали суммами элементов их строк стоящих выше побочной диагонали C++
В матрице заменить значения элементов побочной диагонали на единицы C++
C++ В матрице заменить значения элементов побочной диагонали на единицы

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MarVaL
С++ Beginner
 Аватар для MarVaL
116 / 116 / 16
Регистрация: 28.02.2013
Сообщений: 246
28.05.2013, 13:41     В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0 #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
#include <iostream>
#include <ctime>
#include <cstdlib>
 
int main() {
    srand(time(0));
    const int n = 6;
    int matrix[n][n];
    int max, i_max = 0, j_max = 0;
    for(int i = 0; i < n; ++i) {
        for(int j = 0; j < n; ++j) {
            matrix[i][j] = rand() % 10;
            std::cout << matrix[i][j] << ' ';
        }
        std::cout << std::endl;
    }
 
    max = matrix[0][0];
    
    for(int i = 0; i < n - 1; ++i) {
        for(int j = 0; j < n - 1 - i; ++j) {
            if(max < matrix[i][j]) {
                max = matrix[i][j];
                i_max = i;
                j_max = j;
            }
        }
    }
    
    std::cout << "Max element: " << max << std::endl;
    matrix[i_max][j_max] = 0;
    
    for(int i = 0; i < n; ++i) {
        for(int j = 0; j < n; ++j)
            std::cout << matrix[i][j] << ' ';
        std::cout << std::endl;
    }
    
    return 0;
}
Stastriada95
Сообщений: n/a
28.05.2013, 15:35     В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0 #3
Спасибо большое!!!! Не знаю как Вас благодорить. Одной работы до допуска к экзамену не хватало!! спасибо все работает)))
Yandex
Объявления
28.05.2013, 15:35     В матрице (6,6) найти максимальный из элементов, стоящих выше побочной диагонали и заменить его на 0
Ответ Создать тему
Опции темы

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