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

Передача динамического массива в функции

07.05.2013, 11:48. Показов 1301. Ответов 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
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
#include <iostream>
#include <cstdlib>
using namespace std;
 
/*const*/ int k=3;
//void sum (int mas[k][k]);
void sum (int * arr[], int k, int t);
//void max(int matrix[k][k]);
void max(int * arr[] ,int g, int r);
 
int main(){
 /*       int arr[k][k];*/
 cout << "Vvedi razmernost' massiva \n";
cin >> k;
 
int* * arr= new int*[k]; //çàâåëè äèíàìè÷åñêèé ìàññèâ
for (int i=0; i<=k; i++)
{
    arr[i]=new int[k];
}
 
        int i, j;
 
        for ( i = 0; i < k; i++ ){
                for ( j = 0; j < k; j++ ){
                        cout<< "arr[" << i << "]["<<j<<"] = ";
                        cin >> arr[i][j];// çàïîëíåëè ìàññèâ
                }
        }
 
        cout <<"\n";
        for ( j = 0; j < k; j++ ){
            cout <<"\n";
        for ( i = 0; i < k; i++ )
        cout<< arr[i][j] << "      ";
        }
        cout <<"\n Summa elementov v teh stolbtsax,kotorye ne soderjat otricatelnyh elementov:";
        sum(arr,k,k);
        cout <<"\n Minimum sredi summ elementov diagonalej,parallelnyh pobochnoy diagonali matricy: ";
        max(arr,k,k);
      fflush(stdin);
      char c=getchar();
        return 0;
     //   system("PAUSE");
        delete [] arr;
    //return EXIT_SUCCESS;
}
 
void sum (int * mas[],int k, int t)
{
        int i,j,a,sum,n;
        for (i=0;i<k;i++)
        { 
                a=0;
                sum=-1;
                for (j=0;j<k;j++) {
                if (mas[i][j]<0) a++;
                }
                if (a==0)
                        { 
                        sum=0;
                        for (n=0;n<k;n++){
                        sum+=mas[i][n];
                        }
                        cout << "\n stolbets "<< i << " =  " << sum << "\n"; 
                }
        } 
        if (sum==-1) 
          {
              cout<< " net takix stolbtsov";
        }
}
int sumDiagonal (int matrix,int y, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
void max(int * matrix[],int c, int r)
{
        int min = sumDiagonal(matrix, 0);
        for(int i = 1, cnt; i < k + k - 1; ++i)
        {
                cnt = sumDiagonal(matrix, k, i);
                if(cnt < min)
                        min = cnt;
        }
        cout <<  min;
}

А вопрос такой
Динамически массив отсюда
C++
1
2
3
4
5
6
7
8
9
10
11
void max(int * matrix[],int c, int r)
{
        int min = sumDiagonal(matrix, 0);
        for(int i = 1, cnt; i < k + k - 1; ++i)
        {
                cnt = sumDiagonal(matrix, k, i);
                if(cnt < min)
                        min = cnt;
        }
        cout <<  min;
}
Нужно передать в эту функцию
C++
1
2
3
4
5
6
7
8
9
10
11
int sumDiagonal (int matrix[],int y, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
КАК? Что неправильно?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.05.2013, 11:48
Ответы с готовыми решениями:

Создание динамического массива, передача аргументов функции по ссылке. Программа обрабатывает результаты матча
Разработать программу, предназначенную для обработки информации о матчах, сыгранных футбольной командой. Количество сыгранных матчей и...

Передача динамического массива в функцию
Привет, помогите пожалуйста переделать программку в динамический массив и с помощью передачи массива в функцию #include...

Передача динамического массива в функцию
void create_matrix(float **matr,float * mass,int n1); ....................................................................... void...

10
419 / 418 / 72
Регистрация: 27.05.2012
Сообщений: 1,168
07.05.2013, 12:21
Цитата Сообщение от Харек Посмотреть сообщение
int * matrix[]
и

Цитата Сообщение от Харек Посмотреть сообщение
int matrix[]
ничего не смущает?
0
 Аватар для Харек
3 / 3 / 0
Регистрация: 13.04.2013
Сообщений: 20
07.05.2013, 12:30  [ТС]
Цитата Сообщение от Кудаив Посмотреть сообщение
и

ничего не смущает?
я пробовала и так
C++
1
2
3
4
5
6
7
8
9
10
11
int sumDiagonal (int * matrix[],int y, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
тоже ошибку выдает
0
26 / 26 / 3
Регистрация: 10.04.2013
Сообщений: 167
07.05.2013, 12:42
а тут попробуй так
C++
1
2
3
4
5
6
7
8
9
10
11
int sumDiagonal (int matrix[k][],int y, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
Масив удаляй так..
C++
1
2
3
4
for(int i=0;i<k;i++)
 delete[] arr[k];
 
delete[] arr;
1
 Аватар для Харек
3 / 3 / 0
Регистрация: 13.04.2013
Сообщений: 20
07.05.2013, 12:55  [ТС]
Снова ошибки
Миниатюры
Передача динамического массива в функции  
0
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
07.05.2013, 12:58
C++
1
int sumDiagonal (int matrix[k][],int y, int currentDiagonal)
Это не будет работать вообще (т.к. размер можно не указывать только для первой размерности), а для динамических и подавно.
Для передачи динамического массива используйте
C++
1
int** matrix
, и не забудьте, что дополнительно надо еще передать разрешенные размеры.
0
 Аватар для Харек
3 / 3 / 0
Регистрация: 13.04.2013
Сообщений: 20
07.05.2013, 13:09  [ТС]
Цитата Сообщение от Tulosba Посмотреть сообщение
C++
1
int sumDiagonal (int matrix[k][],int y, int currentDiagonal)
Это не будет работать вообще (т.к. размер можно не указывать только для первой размерности), а для динамических и подавно.
Для передачи динамического массива используйте
C++
1
int** matrix
, и не забудьте, что дополнительно надо еще передать разрешенные размеры.

Если вы имели ввиду та, то это тоже не работает

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int sumDiagonal (int ** matrix,int y, int z, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
void max(int * matrix[],int c, int r)
{
        int min = sumDiagonal(matrix,k,k, 0);
        for(int i = 1, cnt; i < k + k - 1; ++i)
        {
                cnt = sumDiagonal(matrix, k, i);
                if(cnt < min)
                        min = cnt;
        }
        cout <<  min;
}
Миниатюры
Передача динамического массива в функции  
0
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
07.05.2013, 13:39
Харек, у Вас в 17 строке вызов функции с 3мя параметрами, а должен быть с 4мя.
0
 Аватар для Харек
3 / 3 / 0
Регистрация: 13.04.2013
Сообщений: 20
07.05.2013, 13:48  [ТС]
это опечатка была
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int sumDiagonal (int ** matrix,int y, int z, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
void max(int * matrix[],int c, int r)
{
        int min = sumDiagonal(matrix,k,k, 0);
        for(int i = 1, cnt; i < k + k - 1; ++i)
        {
                cnt = sumDiagonal(matrix, k, i);
                if(cnt < min)
                        min = cnt;
        }
        cout <<  min;
}
так не работает
0
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
07.05.2013, 13:58
Цитата Сообщение от Харек Посмотреть сообщение
это опечатка была
И привели код с таким же вызовом.
sumDiagonal должна принимать 4 (четыре) параметра. Вы пытаетесь вызвать с 3(тремя) (строка 18):
C++
1
cnt = sumDiagonal(matrix, k, i);
Добавьте недостающий аргумент.
1
 Аватар для Харек
3 / 3 / 0
Регистрация: 13.04.2013
Сообщений: 20
07.05.2013, 14:02  [ТС]
спасибо) работает)
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int sumDiagonal (int ** matrix,int y, int z, int currentDiagonal)
{
    int sum = 0;
    if(currentDiagonal < k)
        for(int i = -1; i != currentDiagonal; ++i)
            sum += abs(matrix[currentDiagonal - i - 1][i + 1]);
    else
        for(int i = currentDiagonal - k + 1, j = k; i < k; ++i)
            sum += abs(matrix[--j][i]);
    return sum;
}
void max(int * matrix[],int c, int r)
{
        int min = sumDiagonal(matrix,k,k, 0);
        for(int i = 1, cnt; i < k + k - 1; ++i)
        {
                cnt = sumDiagonal(matrix, k,k, i);
                if(cnt < min)
                        min = cnt;
        }
        cout <<  min;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.05.2013, 14:02
Помогаю со студенческими работами здесь

Передача в функцию динамического массива
Всем привет. Есть, например, функция, работающая с динамическим массивом. Допустим я заполняю этот массив нулями. Далее я передаю его в...

Передача динамического массива в функцию
Добрый вечер! Пытаюсь передать динамический массив a с размером n в функцию ii, изменить его, вернуть и вывести. Но выводятся какие-то...

Передача динамического массива в функцию
Помогите разобраться, не могу понять где ошибка. Отлаживал, программа &quot;вываливается&quot; при вызове функции освобождения памяти #include...

Передача динамического массива в функцию
Нужно передать динамический массив в функцию, описав как ссылку (&amp;p). Но я не понимаю, как к нему обращаться в функции.

Передача динамического массива в функцию
Скажите пожалуйста, почему при передаче динамического массива в функцию, адрес локальной переменной (b) отличается от адреса исходной...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru