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

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

07.05.2013, 11:48. Показов 1285. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru