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

Как передать динамический двумерный массив в функцию

20.12.2018, 19:08. Показов 2205. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется массив
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
int main()
{
    setlocale(LC_ALL, "rus");
    int n, m;
    cout << "Введите количество строк: ";
    cin >> n;
    cout << "Введите количество столбцов: ";
    cin >> m;
    cout << endl;
 
    //создание динамического двумерного массива
    int **a = new int*[n]; // строк в массиве
    for (int i = 0; i < n; i++)
    {
        a[i] = new int[m];//столбцов в массиве
    }                       
    // заполнение массива и вывод на экран
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            a[i][j] = rand() % 5;
            cout << a[i][j] << "  " ;
        }
        cout << endl;
    }
}
Нужно передать его в функцию
Пробовала так записать, но по итогу выводит не тот результат.
C++
1
int nul_strok(int** a, int n, int m);
Как будет правильно?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.12.2018, 19:08
Ответы с готовыми решениями:

Как передать в функцию двумерный динамический массив?
#include &lt;iostream&gt; #include&lt;time.h&gt; #include&lt;cstdlib&gt; using namespace std; void zap(int array, int n) { ...

Передать двумерный динамический массив в функцию
Стоит такая задача: Написать функцию, которая в матрице C(3,5) заменяет отрицательные элементы их модулями; положительные элементы,...

Как передать динамический массив в функцию?
Помогите пожалуйста передать динамический массив в функцию. #include &lt;iostream.h&gt; #include &lt;conio.h&gt; #include...

10
Mental handicap
 Аватар для Azazel-San
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
20.12.2018, 19:11
Цитата Сообщение от lilulu Посмотреть сообщение
Пробовала так записать, но по итогу выводит не тот результат.
И почему же не то выводит? Может покажете полностью вашу функцию?
0
1 / 1 / 1
Регистрация: 09.11.2014
Сообщений: 68
20.12.2018, 19:15  [ТС]
Azazel-San,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int nul_strok(int** a, int n, int m)//ищем количество строк, где имеется хотя бы один нулевой элемент
{
    int k = 0;
    for (int i = 0; i < n; i++)// перебираем отдельные строки
    {
        for (int j = 0; j < m; j++)
        {
            if (a[i][j] == 0)//считаем количество строк, где есть ноль
            {
                k++;
                break;
            }
        }
 
    }
    return k;
}
0
Mental handicap
 Аватар для Azazel-San
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
20.12.2018, 19:17
lilulu, и что именно не так?
0
16 / 11 / 6
Регистрация: 18.07.2018
Сообщений: 51
20.12.2018, 19:19
C++
1
void Foo(int **&arr, int rows, int cols)
Передавай его по ссылке

Добавлено через 48 секунд
C++
1
int nul_strok(int**&a, int n, int m)
0
Mental handicap
 Аватар для Azazel-San
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
20.12.2018, 19:25
lilulu, предположу что все дело в том что у вас данные не генерируються заново после каждого нового запуска? А вы подумали что не верно массив передаете?

Добавлено через 2 минуты
Цитата Сообщение от Mikelyndgelo Посмотреть сообщение
Передавай его по ссылке
и что это изменит?
0
1 / 1 / 1
Регистрация: 09.11.2014
Сообщений: 68
20.12.2018, 19:32  [ТС]
Azazel-San,
Проблема в том, что должно быть как на фото 1, а получается как на 2
Миниатюры
Как передать динамический двумерный массив в функцию   Как передать динамический двумерный массив в функцию  
0
Mental handicap
 Аватар для Azazel-San
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
20.12.2018, 19:34
lilulu, то что Вы скинули - это вообще другое, в вашем исходном коде такого нету.. Будем заниматься предсказаниями?
0
1 / 1 / 1
Регистрация: 09.11.2014
Сообщений: 68
20.12.2018, 19:37  [ТС]
Azazel-San,
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
// Для обнаружения утечек памяти 
#define _CRTDBG_MAP_ALLOC 
#include <stdlib.h> 
#include <crtdbg.h>
 
#ifdef _DEBUG 
#ifndef DBG_NEW 
#define DBG_NEW new ( _NORMAL_BLOCK , __FILE__ , __LINE__ ) 
#define newDBG_NEW 
#endif 
#endif
 
 
#include "pch.h"
#include <iostream>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "rus");
    int n, m;
    cout << "Введите количество строк: ";
    cin >> n;
    cout << "Введите количество столбцов: ";
    cin >> m;
    cout << endl;
 
    //создание динамического двумерного массива
    int **a = new int*[n]; // строк в массиве
    for (int i = 0; i < n; i++)
    {
        a[i] = new int[m];//столбцов в массиве
    }                       
    // заполнение массива и вывод на экран
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            a[i][j] = rand() % 5;
            cout << a[i][j] << "  " ;
        }
        cout << endl;
    }
    //ищем количество строк, где имеется хотя бы один нулевой элемент
    int k = 0;
    for (int i = 0; i < n; i++)// перебираем отдельные строки
    {
        for (int j = 0; j < m; j++)
        {
            if (a[i][j] == 0)//считаем количество строк, где есть ноль
            {
                k++;
                break;
            }
        }
        
    }
    cout << "Количество строк, содержащих хотя бы один нулевой элемент : " << k << endl;
    //определяем номер столбца, в котором находится самая длинная серия одинаковых элементов.
    int kol = 0;
    int maxj=0;
    int maxk = 0;
    for (int j = 0; j < m; j++)
    {
        for (int i = 0; i < n-1; i++)
        {
            if (a[i][j] == a[i+1][j])
            {
                kol++;
            }
            else
            {
                break;
            }
            if (kol > maxk)
            {
                maxk = kol;
                maxj=j+1;
            }
        }
    }
    cout <<"Номер столбца с самой длинной последовательностью одинаковых чисел: "<< maxj<<endl;
 
    for (int i = 0; i < n; i++)
    {
        delete[] a[i];
    }
    delete[] a;
    // Для обнаружения утечек памяти
    _CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE);
    _CrtSetReportFile(_CRT_WARN, _CRTDBG_FILE_STDOUT);
    _CrtSetReportMode(_CRT_ERROR, _CRTDBG_MODE_FILE);
    _CrtSetReportFile(_CRT_ERROR, _CRTDBG_FILE_STDOUT);
    _CrtSetReportMode(_CRT_ASSERT, _CRTDBG_MODE_FILE);
    _CrtSetReportFile(_CRT_ASSERT, _CRTDBG_FILE_STDOUT);
    _CrtDumpMemoryLeaks();
    return 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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
// Для обнаружения утечек памяти 
#define _CRTDBG_MAP_ALLOC 
#include <stdlib.h> 
#include <crtdbg.h>
 
#ifdef _DEBUG 
#ifndef DBG_NEW 
#define DBG_NEW new ( _NORMAL_BLOCK , __FILE__ , __LINE__ ) 
#define newDBG_NEW 
#endif 
#endif
 
#include "pch.h"
#include <iostream>
using namespace std;
 
int nul_strok(int** a, int n, int m);
int num_stolb(int** a, int n, int m);
 
 
int main()
{
    setlocale(LC_ALL, "rus");
    int n, m;
    cout << "Введите количество строк: ";
    cin >> n;
    cout << "Введите количество столбцов: ";
    cin >> m;
    cout << endl;
 
    //создание динамического двумерного массива
    int **a = new int*[n]; // строк в массиве
    for (int i = 0; i < n; i++)
    {
        a[i] = new int[m];//столбцов в массиве
    }
    // заполнение массива и вывод на экран
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            a[i][j] = rand() % 5;
            cout << a[i][j] << "  ";
        }
        cout << endl;
    }
    cout << "Количество строк, содержащих хотя бы один нулевой элемент : " << nul_strok << endl;
    cout << "Номер столбца с самой длинной последовательностью одинаковых чисел: " << num_stolb << endl;
    for (int i = 0; i < n; i++)
    {
        delete[] a[i];
    }
    delete[] a;
    // Для обнаружения утечек памяти
    _CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE);
    _CrtSetReportFile(_CRT_WARN, _CRTDBG_FILE_STDOUT);
    _CrtSetReportMode(_CRT_ERROR, _CRTDBG_MODE_FILE);
    _CrtSetReportFile(_CRT_ERROR, _CRTDBG_FILE_STDOUT);
    _CrtSetReportMode(_CRT_ASSERT, _CRTDBG_MODE_FILE);
    _CrtSetReportFile(_CRT_ASSERT, _CRTDBG_FILE_STDOUT);
    _CrtDumpMemoryLeaks();
    return 0;
 
}
 
int nul_strok(int** a, int n, int m)//ищем количество строк, где имеется хотя бы один нулевой элемент
{
    int k = 0;
    for (int i = 0; i < n; i++)// перебираем отдельные строки
    {
        for (int j = 0; j < m; j++)
        {
            if (a[i][j] == 0)//считаем количество строк, где есть ноль
            {
                k++;
                break;
            }
        }
 
    }
    return k;
}
 
int num_stolb(int** a, int n, int m)//определяем номер столбца, в котором находится самая длинная серия одинаковых элементов.
{
    int kol = 0;
    int maxj = 0;
    int maxk = 0;
    for (int j = 0; j < m; j++)
    {
        for (int i = 0; i < n - 1; i++)
        {
            if (a[i][j] == a[i + 1][j])
            {
                kol++;
            }
            else
            {
                break;
            }
            if (kol > maxk)
            {
                maxk = kol;
                maxj = j + 1;
            }
        }
    }
    return maxj;
}
0
Mental handicap
 Аватар для Azazel-San
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
20.12.2018, 19:43
Лучший ответ Сообщение было отмечено lilulu как решение

Решение

lilulu, а вызывать функции кто за вас будет?

Добавлено через 2 минуты
Цитата Сообщение от lilulu Посмотреть сообщение
C++
1
<< nul_strok << endl;
Где скобки и передача параметров функции? В вашем случае вы просто получаете адрес функции в памяти.
1
1 / 1 / 1
Регистрация: 09.11.2014
Сообщений: 68
20.12.2018, 20:21  [ТС]
Azazel-San,
да, и правда)Упустила. Теперь все работает. Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.12.2018, 20:21
Помогаю со студенческими работами здесь

Как передать динамический массив в функцию, чтобы он изменился?
Через указатель не изменяется:(

Как передать в функцию двухмерный динамический массив по ссылке?
как передать в функцию двухмерный динамический массив по ссылке?

Как передать динамический массив из функции в другую функцию
Здравствуйте.Не могу передать массив из функции в функцию сортировки. Подскажите как переделать программу : #include...

Как передать двумерный массив в функцию?
например у меня есть двумерный массив 5 на 5.мне нужна функция в которой будет запрашиваться столбец и строка а затем элементу из этого...

Как можно использовать двумерный динамический массив в си++ через функцию
Коротко говоря мне бы осознание синтаксиса чтоб я понимал. Вот есть двумерный динамический массив (также можно написать мне код на трёх...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru