Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 1
Регистрация: 09.12.2010
Сообщений: 10

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

18.12.2011, 16:23. Показов 1580. Ответов 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
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.12.2011, 16:23
Ответы с готовыми решениями:

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

Реализовать мониторинг использования динамически распределяемой памяти.
Здравствуйте, мне в лабораторке нужно реализовать мониторинг динамически распределяемой памяти. Хотелось бы узнать, как это можно сделать.

Хранения матриц в динамически распределяемой области памяти
Скажите пожалуйста или приведите пример хранения матриц в динамически распределяемой области памяти, для трёх случаев: а) число строк -...

2
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
18.12.2011, 17:13
C
1
2
3
for(j=m-1; j>=0; j--)
  if ((matr[i][j]%2)==0) ... // Вот он - последний четный
if (j<0) ... // Четных элементов в строке нет
1
0 / 0 / 1
Регистрация: 09.12.2010
Сообщений: 10
18.12.2011, 20:53  [ТС]
спасибо! хотя я уже сам сделал, додумался , только немножко иначе
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.12.2011, 20:53
Помогаю со студенческими работами здесь

Работа с массивом указателей на двумерные динамически выделяемые массивы
Здравствуйте. Подскажите пожалуйста, как реализовать следующую задачу: В структуре есть массив из трёх указателей на двумерные...

Выделение памяти под массивы динамически
Помогите пожалуйста, нужно выделить память под массивы динамически Вот такая задача: Упорядочить массивы Х(К), Y(К), К &lt;= 350 по...

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

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

Табулирование функции и поиск данных. Одномерные массивы. Двумерные массивы
Вычислить сумму первых четырех отрицательных элементов. В соответствии с п. 5.16 правил &quot;Запрещено создавать темы с множеством...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru