Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
s.talke.r
0 / 0 / 1
Регистрация: 09.12.2010
Сообщений: 10
1

Двумерные массивы. Использование динамически распределяемой памяти

18.12.2011, 16:23. Просмотров 643. Ответов 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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include <iostream>
#include <conio.h>
#include <time.h>
#include <iomanip>
#include <stdio.h>
using namespace std;
void matrix_create(int n, int m, int** matr)
{   srand((unsigned) time(0));
    for(int i=0; i<n; i++)
      for(int j=0; j<m; j++)
        matr[i][j]=rand()%15;
}   
 
void matrix_chet(int n,int m, int** matr)
{   
    int i,j,ch,k=1,max;
    int* rez;
    rez = new  int[n];
 
    
    for (i=0; i<n; i++)
        { 
            max=0;
            for (j=0; j<m; j++)
                if (matr[i][j]>max)
                {
                    max=matr[i][j];
                    rez[i]=max;
                    
                }
        }
                
    cout << "\nNovaj MATRIX:\n";
    cout << "\n-----------------------------------\n";
    for(i=0; i<n; i++) 
    {
            cout << rez[i]<<"  ";
            cout << endl;
    }
    cout << "\n-----------------------------------\n";
} 
int main()
{
int **pint;     
    int n,m,i,j,max;    
    cout << "Vvedite n,m -> "; 
    cin >> n >> m; 
    pint=new int*[n]; // Создание вспомогательного массива указателей
    for(i=0; i<n; i++) 
    {
        pint[i]=new int[m];
    }   
    matrix_create(n,m,pint);
cout << "\nSformirovana MATRIX:\n";
    cout << "\n-----------------------------------\n";
    for(i=0; i<n; i++) 
    {
        for(j=0; j<m; j++) 
            cout << "\t" << pint[i][j];
            cout << endl;
    }
 cout << "\n-----------------------------------\n";
 matrix_chet(n,m, pint);
delete[] pint; 
getch();
return 0;
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.12.2011, 16:23
Ответы с готовыми решениями:

Нужно ли удалять указатель на символьный массив созданный в куче(динамически распределяемой памяти)
Подскажите, программа состоит из 2 функций (main и fun), программа меняет...

Двумерные динамические массивы-матрицы (выделение памяти)
Помогите пожалуйста,разобраться. В динамической памяти сначала выделяется...

Использование шаблонов функций в задаче на двумерные массивы
Уважаемые программисты, необходима ваша помощь. Условие задачи:Дана...

Двумерные массивы.
Помогите решить задачку!!!!!! Дана действительная квадратная матрица порядка...

Двумерные массивы
Никогда особо раньше не занимался программирование,больше как то математикой.И...

2
Байт
Эксперт C
18318 / 12029 / 2506
Регистрация: 24.12.2010
Сообщений: 24,293
18.12.2011, 17:13 2
C
1
2
3
for(j=m-1; j>=0; j--)
  if ((matr[i][j]%2)==0) ... // Вот он - последний четный
if (j<0) ... // Четных элементов в строке нет
1
s.talke.r
0 / 0 / 1
Регистрация: 09.12.2010
Сообщений: 10
18.12.2011, 20:53  [ТС] 3
спасибо! хотя я уже сам сделал, додумался , только немножко иначе
C++
1
2
3
4
5
6
7
8
9
10
11
12
for (i=0; i<n; i++)
        {   
            do
            {
                for (j=0; j<m; j++)
                    if (matr[i][j]%2==0)
                {
                    ch=matr[i][j];
                    rez[i]=ch;      
                }
            } while (matr[i][j]/2==0);
        }
спасибо все равно!
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.12.2011, 20:53

Двумерные массивы
Привет всем! если есть у кого время, посмотрите что можно сделать, нужна ваша...

Двумерные массивы в С++
Написать программу, которая дает пользователю ввести 5 фамилий студентов, а...

двумерные массивы
Составить программу обмена местами максимального и минимального элементов...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

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