Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.83/29: Рейтинг темы: голосов - 29, средняя оценка - 4.83
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
1

Двумерный массив в качестве параметра функции

01.05.2010, 21:30. Просмотров 5786. Ответов 21
Метки нет (Все метки)

почему не удаётся передать в качестве параметра двумерный массив?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream.h>
 
int sum(const int** mas, const int l,const int m);
 
int const l = 2, m=4;
 
int main(){
 
    const int marks[l][m]={{1,2,-4,6},{0,5,-2,8}};
 
    cout<< sum(marks, l,m);
    return 0;
}
 
int sum(const int** mas, const int l,const int m) 
{int s = 0;
for (int i = 0 ; i<l; i++)
for (int j = 0 ; j<l; j++)
  s += mas[i][j];
 return s;}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.05.2010, 21:30
Ответы с готовыми решениями:

двумерный массив в качестве параметра метода класса
Добрый день Есть проблемка, попробую упростить условия по максимуму: В программе меется некоторый...

Динамический массив структуры в качестве параметра функции
Привет! Нужна помощь ( Есть структура struct Embedded { double density; double energy; } ...

Как передать массив структур в функцию в качестве параметра, чтобы изменения в функции меняли исходный массив?
Допустим есть структура struct Base { int a; int b; int c; }; В...

Передача функции в качестве параметра
#include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; double f(double x) { return...

21
1257 / 795 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
01.05.2010, 21:32 2
Таким способом передаются динамические матрицы, то есть двойной указатель принимает адрес
первого указателя: на первую строку матрицы.
0
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
01.05.2010, 21:39  [ТС] 3
а как тогда?
0
Модератор
Автор FAQ
3682 / 959 / 114
Регистрация: 10.01.2010
Сообщений: 2,550
01.05.2010, 22:01 4
Цитата Сообщение от velodro Посмотреть сообщение
а как тогда?
Можно так...
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream.h>
 
int sum(const int* mas, const int l,const int m);
 
int const l = 2, m=4;
 
int main(){
 
        const int marks[l][m]={{1,2,-4,6},{0,5,-2,8}};
 
        cout<< sum(&marks[0][0], l,m);
        return 0;
}
 
int sum(const int* mas, const int l,const int m) 
{int s = 0;
for (int i = 0 ; i<l; i++)
for (int j = 0 ; j<l; j++)
  s += mas[l*i+j];
 return s;}
1
Эксперт С++
2330 / 1703 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
01.05.2010, 23:08 5
insideone, все бы хорошо, но попробуй в приведенную тобой функцию передать "динамическую" матрицу - результат будет плачевным.
0
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
01.05.2010, 23:37  [ТС] 6
s += mas[l*i+j];
а вот это почему так?
и второе - почему в последнем варианте нельзя вот так: s += mas[i][j];
0
Эксперт С++
2330 / 1703 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
01.05.2010, 23:43 7
velodro, если тебе необходимо использовать только "статическую" матрицу то вот:
C++
1
2
3
4
5
6
7
8
9
10
template<size_t n, size_t m>
int Sum(int (&matrix)[n][m]) {
  int result = 0;
 
  for (int i = 0; i < n; ++i)
    for (int j = 0; j < m; ++j)
      result += matrix[i][j];
 
  return result;
}
0
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
02.05.2010, 01:02  [ТС] 8
а скажите, пожалуйста, как тогда будет выглядеть вызов функции Sum в главной функции

я думал так-
cout<< sum((&marks)[l][m]);
но не пашет...
0
Эксперт С++
2330 / 1703 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
02.05.2010, 01:52 9
velodro,
C++
1
cout << sum(marks);
0
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
02.05.2010, 01:54  [ТС] 10
и эта тоже не пашет...
0
Эксперт С++
2330 / 1703 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
02.05.2010, 02:06 11
Лучший ответ Сообщение было отмечено как решение

Решение

velodro, а поподробнее?
Все работает:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
 
template<size_t n, size_t m>
int Sum(int (&matrix)[n][m]) {
  int result = 0;
 
  for (int i = 0; i < n; ++i)
    for (int j = 0; j < m; ++j)
      result += matrix[i][j];
 
  return result;
}
 
int main() {
  int matrix[][4] = {
    {1, 2, 3, 4},
    {5, 6, 7, 8},
  };
 
  std::cout << Sum(matrix) << std::endl;
 
  return 0;
}
1
1257 / 795 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
02.05.2010, 11:44 12
Лучший ответ Сообщение было отмечено как решение

Решение

Если бы не было шаблонов????
Будет представление матрицы как простого массива, какая то кривизна получается.
Да язык C++ меня удивляет своей силой, но некоторые вещи в языке
стоило бы привести в порядок...
В конце концов придумали какую-нибудь фичу для передачи матриц,
динамических + статических(одинаково), что бы все было просто как с массивами.
Наверное, ни кто не хочет ни чего придумывать, потому как всех все устраивает,
только один я не доволен, этой кособокостью......
.......

Добавлено через 21 минуту
Вот уже придумал вещицу, только это надо в реализации языка делать.
Вариант вполне нормальный...
Передача стек матрицы, через массив указателей наведенных на матрицу

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
#include <iostream>
using namespace std;
 
 
void print(int **matrix , int h , int w);
int main(){
const int H = 3;
const int W = 3;
int matrix[H][W] = {
    {1,2,3},
    {4,5,6},
    {7,8,9}
 
};
int *pmatr[H] = {NULL};
pmatr[0] =&matrix[0][0];
pmatr[1] =&matrix[1][0];
pmatr[2] =&matrix[2][0];
print(pmatr,H,W);
 
return 0;
}
 
void print(int **matrix , int h , int w){
    for( int i = 0; i < h ; i++){
        for( int j = 0 ; j < w; j++){
        cout<<matrix[i][j]<<' ';
        }
     cout<<endl;
    }
 
}

......

Добавлено через 21 минуту
.......
2
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
02.05.2010, 18:16  [ТС] 13
CyBOSSeR, выдаёт вот такие ошибки..

Код
error C2265: '<Unknown>' : reference to a zero-sized array is illegal  (стр. 4)
error C2087: '<Unknown>' : missing subscript       (стр. 4)
error C2783: 'int __cdecl Sum(int (&)[1][1])' : could not deduce template argument for 'n'  (стр. 20)
error C2783: 'int __cdecl Sum(int (&)[1][1])' : could not deduce template argument for 'm'   (стр. 20)
и мне вот что не понятно: в качестве параметра можно давать имя массива и его размерность.. так для одномерного массива, но ведь первая переменная многомерного массива занимает тоже одну ячейку. Почему тогда нельзя сделать по аналогии с одномерным массивом. например:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int sum(int mas[][],const int l,const int m);
 
int main(){
 
    int marks[l][m]={{1,2,-4,6},{0,5,-2,8}};
    cout<< sum(marks,l,m);
    return 0;
}
 
int sum(int mas[][],const int l,const int m)
{
    int s = 0;
    for (int i=0 ; i<m; i++)
        for (int j=0 ; j<m; j++)
            s += mas[i][j];
    return s;
}
0
Эксперт С++
2330 / 1703 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
02.05.2010, 18:33 14
velodro, приведенный код прекрасно работает в MSVS 2008, так что проблем не должно быть. В чем программируешь?
1
Ignat
02.05.2010, 18:35
  #15

Не по теме:


Подозреваю это VC++ 6.0.

0
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
02.05.2010, 18:38  [ТС] 16
msvs 6.0
наверное не понимает template<size_t n, size_t m>
но да ладно.. мне нужно понять как сделать это самым стандартным образом для любого компилятора..
и всё же решение проблемы в использовании указателей на массив?
0
1257 / 795 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
02.05.2010, 18:58 17
Проверил на своем VC++ 6.0 все точно как у тебя.
Вариант с массивом указателей можешь автоматизировать циклом:
C++
1
2
for( int i = 0; i < H ; i++)pmatr[i] = &matrix[i][0];
print(pmatr,H,W);
0
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
02.05.2010, 21:20  [ТС] 18
а что в качестве параметра функции нужно использовать одномерный массив указателей на переменные многомерного массива? можете элементарно объяснить - как в должен выглядеть параметр - многомерный массив в описании создаваемой функции и как должен выглядеть этот параметр при вызове этой функции?... хотелось бы конкретики.
0
1257 / 795 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
02.05.2010, 21:53 19
можете элементарно объяснить - как в должен выглядеть параметр - многомерный массив в описании создаваемой функции
Так: Type ** matrix;
matrix - это двойной указатель..
Двойной указатель предназначен для хранения адреса простого указателя.
Массив указателей реализуется на основе двойного константного указателя..
Двойной константный указатель всегда хранит адрес 1 первого указателя [0].


Мы передаем в функцию адрес первого указателя: наведенного на первую строку матрицы.

[][] - операция
-Первый параметр операции: первая скобка задает смещение:
указатель на какую строку должен использоваться, для дальнейшего смещения операцией ->
второй скобкой.

Если не понял, извиняй, указатели: это тема не из легких.
1
72 / 1 / 3
Регистрация: 28.11.2009
Сообщений: 78
02.05.2010, 22:15  [ТС] 20
int sum(int **mas[][],const int l,const int m); - так должны выглядеть параметры в описании создаваемой функции?
как тогда должны выглядеть параметры при вызове функции в главной функции?
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
02.05.2010, 22:15

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Передача функции в качестве параметра
Как передать функцию с параметрами в transform? Т.е., например, мне надо из каждого числа вектора...

Указатель на функцию в качестве параметра функции
ln(1-x)+sinx необходимо создать программу демонстрирующую возможность использования указателя на...

Функции, передача массива в качестве параметра
Приветствую) Собственно, есть простенькое задание с двумерными массивами, оно выполнено: ...

Передача CString в качестве параметра функции
Добрый всем вечер! Мучает один вопрос, на который не могу найти ответ. Как наилучшим образом...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.