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

Найти максимальный элемент среди положительных элементов матрицы А - C++

Восстановить пароль Регистрация
 
k236
0 / 0 / 0
Регистрация: 23.11.2012
Сообщений: 2
19.11.2014, 23:47     Найти максимальный элемент среди положительных элементов матрицы А #1
Доброго времени суток!

Задание такое вот:
Дана матрица А(5,5) задать из файла. Найти новый одномерный массив С из произведений элементов каждой строки матрицы А. Найти максимальный элемент , среди положительных элементов матрицы А. Заменить третий элемент в 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
50
51
52
53
54
55
56
57
58
59
60
#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <iomanip>
using namespace std;
void main(){
 
const int n = 5;
 
int i,j,a[n][n],b[n],p,max,imax,jmax;
fstream file;
file.open("1.txt", ios::in);
for(i=0; i<n; i=i+1){
   for(j=0; j<n; j=j+1){
      file>>a[i][j];
        }
}
for(i=0; i<n; i=i+1){
   for(j=0; j<n; j=j+1){
      cout<<setw(6)<<a[i][j];
   }
   cout<<endl;
}
 
file.close();
 
for(i=0; i<n; i=i+1){
   p=1;   
       for(j=0; j<n; j=j+1){
           
           p=p*a[i][j];
           b[i]=p;
 
   }
}
for (i=0; i<n; i++){
cout<<"b[i]="<<b[i]<<endl;
}
max=-10E10;
imax=0;
jmax=0;
for(i=0; i<n; i=i+1){
   for(j=0; j<n; j=j+1){
     if (a[i][j]>max){
         max=a[i][j];
         imax=i;
         jmax=j;}
   }
   
}
cout<<"max="<<max<<" imax="<<imax<<" jmax="<<jmax<<endl;
a[0][2] = max;
for(i=0; i<n; i=i+1)
     {
            for(j=0; j<n; j=j+1)
                    cout<<a[i][j]<<" ";
            cout<<endl;
     }
   
}
но новый одномерный массив С из произведений элементов каждой строки матрицы А нужно сделать через указатель, что сделать не получается. Помогите, пожалуйста!
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.11.2014, 23:47     Найти максимальный элемент среди положительных элементов матрицы А
Посмотрите здесь:

C++ Найти максимальный элемент матрицы среди элементов, расположенных левее 4-го столбца
C++ Определить максимальный элемент среди положительных нечетных элементов и минимальный среди положительных четных элементов
В целочисленном массиве найти максимальный элемент среди четных и среди нечетных элементов C++
C++ В массиве найти максимальный элемент среди положительных элементов массива
Определить максимальный элемент среди положительных элементов C++
Массивы. Найти максимальный элемент среди всех элементов тех строк заданной матрицы, которые упорядочены C++
Найти максимальный элемент среди всех элементов тех строк заданной матрицы А (4,4), которые упорядочены по возрастанию C++
Найти макс. элемент среди отрицательных и мин. элемент среди положительных элементов массива C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Nosey
 Аватар для Nosey
1184 / 351 / 102
Регистрация: 22.10.2014
Сообщений: 786
Завершенные тесты: 2
20.11.2014, 00:38     Найти максимальный элемент среди положительных элементов матрицы А #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
.....
 
    file.close();
 
    int* bPtr = b; // Получаем указатель на массив, он указывает на нулевой элемент массива.
    for (i = 0; i < n; i = i + 1)
    {
        p = 1;
        for (j = 0; j < n; j = j + 1)
        {
            p = p*a[i][j];
            //b[i] = p; // внесём значение используя указатели.
        }
        *bPtr = p; // Разыменовываем указатель и присваиваем ему сумму элементов.
        bPtr++; // Инкрементируем указатель, и теперь bPtr ссылается на следующий элемент массива b
    }
    for (i = 0, bPtr = b; i < n; i++, ++bPtr) // опять получим указатель на нулевой элемент массива на каждой итерации его инкрементируем.
    {
        //cout << "b[i]=" << b[i] << endl;// выведем значение используя указатели.
        cout << "b[i]=" << *bPtr << endl; // Разыменовываем и выводим.
    }
......
k236
0 / 0 / 0
Регистрация: 23.11.2012
Сообщений: 2
20.11.2014, 16:35  [ТС]     Найти максимальный элемент среди положительных элементов матрицы А #3
Nosey, спасибо тебе!
Yandex
Объявления
20.11.2014, 16:35     Найти максимальный элемент среди положительных элементов матрицы А
Ответ Создать тему
Опции темы

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