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

передача массивов в функцию

11.08.2016, 14:21. Показов 1240. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
собственно пишу программу. В мэйне прописываю условные массивы и передаю в функцию генерации массивов.
Собственно при выполнении почему то выскакивает исключение
"Возникло необработанное исключение по адресу 0x75FADAE8 в ConsoleApplication1.exe: исключение Microsoft C++: std::bad_alloc по адресу памяти 0x012FF434."

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <fstream>
#include "mg.h"
using namespace std;
const int FINE_MESH = 0;
 
void main()
{
    double ****phi, ***phi_exact, ****f, ****x, ****y, ****z, ****aux;
    int n_nodes = 1025;
    int n_levels;
    cout << "allocate arrays" << endl;
    n_levels = allocate_arrays(&phi, &phi_exact, &f, &x, &y, &z, &aux, n_nodes);
    cout << "generate fine mesh" << endl;
    generate_fine_mesh(x[FINE_MESH], y[FINE_MESH], z[FINE_MESH], n_nodes, true);
    cin >> n_levels;
}

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
#include "mg.h"
#include <iostream>
using namespace std;
 
int allocate_arrays(double *****phi, double ****phi_exact, double *****f, double *****x, double *****y, double *****z, double *****aux, int n_nodes)
{
    double ****x_temp, ****y_temp, ****z_temp, ****phi_temp, ****f_temp, ****aux_temp;
    double ***phi_exact_temp;
    bool coarsen = true; int n_levels = 1; int nodes = n_nodes;
    while (coarsen) {
        if (((nodes - 1) % 2 == 0) && ((nodes - 1) / 2 + 1 >= 3)) {
            nodes = (nodes - 1) / 2 + 1;
            n_levels++;
        }
        else {
            coarsen = false;
        }
    }
 
    x_temp = new double***[n_levels];
    y_temp = new double***[n_levels];
    z_temp = new double***[n_levels];
    phi_temp = new double***[n_levels];
    f_temp = new double***[n_levels];
    aux_temp = new double***[n_levels];
    phi_exact_temp = new double**[n_levels];
    nodes = n_nodes;
    for (int i_level = 0; i_level < n_levels; i_level++)
    {
        x_temp[i_level] = new double**[nodes];
        y_temp[i_level] = new double**[nodes];
        z_temp[i_level] = new double**[nodes];
        phi_temp[i_level] = new double**[nodes];
        f_temp[i_level] = new double**[nodes];
        aux_temp[i_level] = new double**[nodes];
        for (int i = 0; i < nodes; i++)
        {
            x_temp[i_level][i] = new double*[nodes];
            y_temp[i_level][i] = new double*[nodes];
            z_temp[i_level][i] = new double*[nodes];
            phi_temp[i_level][i] = new double*[nodes];
            f_temp[i_level][i] = new double*[nodes];
            aux_temp[i_level][i] = new double*[nodes];
            for (int j = 0; j < nodes; j++) {
                x_temp[i_level][i][j] = new double[nodes];
                y_temp[i_level][i][j] = new double[nodes];
                z_temp[i_level][i][j] = new double[nodes];
                phi_temp[i_level][i][j] = new double[nodes];
                f_temp[i_level][i][j] = new double[nodes];
                aux_temp[i_level][i][j] = new double[nodes];
            }
        }
        nodes = (nodes - 1) / 2 + 1;
    }
    nodes = n_nodes;
    for (int i = 0; i < nodes; i++)
    {
        phi_exact_temp[i] = new double*[nodes];
        for (int j = 0; j < nodes; j++) {
            phi_exact_temp[i][j] = new double[nodes];
        }
    }
    **x = *x_temp;
    **y = *y_temp;
    **z = *z_temp;
    **f = *f_temp;
    **aux = *aux_temp;
    **phi_exact = *phi_exact_temp;
    return n_levels;
}
void generate_fine_mesh(double ***x, double ***y, double ***z, int n_nodes, bool visualize)
{
    for (int i = 0; i < n_nodes; i++) {
        for (int j = 0; j < n_nodes; j++) {
            for (int k = 0; k < n_nodes; k++) {
                x[i][j][k] = (double)i / (double)(n_nodes - 1);
                y[i][j][k] = (double)j / (double)(n_nodes - 1);
                z[i][j][k] = (double)k / (double)(n_nodes - 1);
            }
        }
    }
    cout << "создана сетка(" << n_nodes << "x" << n_nodes << ")";
}
помогите разобраться в чем дело...
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.08.2016, 14:21
Ответы с готовыми решениями:

Передача в функцию 2х массивов
Подскажите, как передать в функцию 2 массива? С одним всё понятно, но как передать 2 , как будут различаться 2 указателя?

Передача массивов в функцию на С++
Здравствуйте. Подскажите пожалуйста, как в приведенной ниже программе передать два массива в функцию, чтобы не прописывать два цикла в...

Передача массивов в функцию
Определить функции, выполняющие действия в соответствии с заданием.Написать на я зыке С++ Дан одномерный массив, состоящий из N...

7
2393 / 1920 / 763
Регистрация: 27.07.2012
Сообщений: 5,561
11.08.2016, 14:47
Цитата Сообщение от beherit666 Посмотреть сообщение
помогите разобраться в чем дело...
В количестве звёздочек: double *****phi.

А если по теме, то память кончилась, судя по всему.
0
0 / 0 / 0
Регистрация: 28.04.2015
Сообщений: 5
11.08.2016, 14:52  [ТС]
тогда какие аргументы должны быть в функции, чтобы можно было отправлять в неё неинициализированные массивы?
0
Падаван С++
 Аватар для obivan
447 / 261 / 89
Регистрация: 11.11.2014
Сообщений: 916
11.08.2016, 14:55

Не по теме:

Цитата Сообщение от John Prick Посмотреть сообщение
В количестве звёздочек: double *****phi.
:D вот тут то тема с goto поможет, все будут щас советовать как выходить из циклов с 5 мерными массивами :popcorn:



Добавлено через 1 минуту
beherit666, а можно поинтересоватся, а зачем собственно такие нагромождения ? какая задача вообще стоит, может как то по другому можно
0
0 / 0 / 0
Регистрация: 28.04.2015
Сообщений: 5
11.08.2016, 15:07  [ТС]
Цитата Сообщение от obivan Посмотреть сообщение

Не по теме:

:D вот тут то тема с goto поможет, все будут щас советовать как выходить из циклов с 5 мерными массивами :popcorn:



Добавлено через 1 минуту
beherit666, а можно поинтересоватся, а зачем собственно такие нагромождения ? какая задача вообще стоит, может как то по другому можно
нужно объявить 6 4-х мерных массивов, отправить их в функцию для выделения памяти на них
0
Падаван С++
 Аватар для obivan
447 / 261 / 89
Регистрация: 11.11.2014
Сообщений: 916
11.08.2016, 15:16
beherit666, сделайте отдельную функцию которая принимает, 1 4х мерный массив, и передавайте туда ссылку на него и размеры, для простоты в размерах передавайте все время 1
0
0 / 0 / 0
Регистрация: 28.04.2015
Сообщений: 5
11.08.2016, 15:37  [ТС]
Добавлено через 35 секунд
Цитата Сообщение от obivan Посмотреть сообщение
beherit666, сделайте отдельную функцию которая принимает, 1 4х мерный массив, и передавайте туда ссылку на него и размеры, для простоты в размерах передавайте все время 1
на мелких размерностях 10,100 всё хорошо, дальше уже вызов исключения
0
2393 / 1920 / 763
Регистрация: 27.07.2012
Сообщений: 5,561
11.08.2016, 15:38
Лучший ответ Сообщение было отмечено beherit666 как решение

Решение

beherit666, память закончилась, о чём исключение и сообщает.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.08.2016, 15:38
Помогаю со студенческими работами здесь

Передача массивов в функцию
M128K145, Тема: Передача масивів у функцію. Задание: Виконати завдання лабораторних робіт №13 (Програмування операцій з одновиміпними...

Передача массивов в функцию
Здравствуйте Друзья! Задание такое. Дан одномерный массив, состоящий из N вещественных элементов Найти минимальный отрицательный элемент....

Передача массивов в функцию
Вычислить z=(xmax-ymin)/(xmin-ymax) с использованием функции, где xmax ,xmin ,ymax ,ymin – максимальные и минимальные элементы...

Передача массивов в функцию
Вычислить z=(xmax-ymin)/(xmin-ymax) с использованием функции, где xmax ,xmin ,ymax ,ymin – максимальные и минимальные элементы...

Передача массивов в функцию
Помогите с программой пожалуйста!! Конец года, горю.. 1)Вычислить с использованием функции max элементы каждой строки матрицы A(10,20)....


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru