Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Gryphon25
0 / 0 / 0
Регистрация: 07.09.2012
Сообщений: 7
#1

Управление двухмерным массивом из функции - C++

16.09.2012, 18:31. Просмотров 587. Ответов 6
Метки нет (Все метки)

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

Я предполагал, что выглядеть будет как-то так:
C++
1
2
3
4
5
6
7
8
9
10
...
 
void abc(char** a){
a[0][0] = 1;
}
 
main(...){
char a[2][5];
abc(a);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.09.2012, 18:31
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Управление двухмерным массивом из функции (C++):

В С++ может ли argv быть двухмерным массивом? - C++
int main(int argc, char *argv) { argv = tolower(argv); argv = tolower(argv); Вот что это означает? Когда у argv с двумя...

Работа с двухмерным динамеческим массивом через указатель - C++
Натупил здесь наверное сильно, подскажите ребят, а то долго уже сиджу над этим... Где ошибки? Программу компилирует, но потом выбивает. ...

Объявление функции с массивом - C++
Сейчас задам очень странный вопрос) Что это значит: int F1(char) не могу понять)) спасибо! Добавлено через 25 минут и вот ещё...

перегрузка функции с массивом - C++
суть такая, если первый массив размерностью больше, чем второй, то прога крашится, если они равны или наоборот меньше, то все ок, почему...

Ошибка в функции с динамическим массивом - C++
Данный код у меня выдаёт ошибку :Необработанное исключение в "0x01281d09" в "Chernovick.exe": 0xC0000005: Нарушение прав доступа при чтении...

Работа с массивом указателей на функции - C++
У нас есть класс Menu в котором есть наши подпункты меню и функция void (#F)(). Для каждого подпункта меню есть своя функция. Указатели на...

6
yekka
386 / 150 / 8
Регистрация: 12.05.2011
Сообщений: 450
16.09.2012, 18:41 #2
у тебя сейчас функция принимает указатель на одномерный массив указателей, каждый из которых указывает на массив чаров.
надо как-то так
C++
1
2
3
4
5
6
7
8
void abc(char a[][5]){
  a[0][0] = 1;
}
 
int main(){
  char a[2][5];
  abc(a);
}
0
Gryphon25
0 / 0 / 0
Регистрация: 07.09.2012
Сообщений: 7
16.09.2012, 19:52  [ТС] #3
Цитата Сообщение от yekka Посмотреть сообщение
abc(char a[][5])
А так получается, что я ограничиваю входной массив...
0
Gryphon25
0 / 0 / 0
Регистрация: 07.09.2012
Сообщений: 7
17.09.2012, 20:32  [ТС] #4
Ну как же создать функцию, в которую можно передать массив неограниченной размерности? Если создавать указатель на двухмерный массив, то, как я понял, необходимо создать массив указателей и каждой ячейке присвоить указатель на каждую главную ячейку двухмерного массива:
C++
1
2
3
4
5
6
        char ss[2][5];
 
    char **us = new char*[sizeof(ss)];
    for(int i = 0; i < sizeof(ss); i++){
        us[i] = ss[i];
    }
Нет ли путей короче? Нигде так и не нашёл ответа, просьба помочь.
0
yekka
386 / 150 / 8
Регистрация: 12.05.2011
Сообщений: 450
17.09.2012, 21:11 #5
C++
1
2
3
4
5
6
7
8
9
template <int N>
void abc(char a[][N]){
  a[0][0] = 1;
}
 
int main(){
  char a[2][5];
  abc(a);
}
0
Topotun
89 / 48 / 7
Регистрация: 16.09.2012
Сообщений: 207
18.09.2012, 02:12 #6
Цитата Сообщение от Gryphon25 Посмотреть сообщение
Ну как же создать функцию, в которую можно передать массив неограниченной размерности? Если создавать указатель на двухмерный массив, то, как я понял, необходимо создать массив указателей и каждой ячейке присвоить указатель на каждую главную ячейку двухмерного массива:
Код C++
1
2
3
4
5
6
7
8
char ss[2][5];
char **us = new char*[sizeof(ss)];
* * for(int i = 0; i < sizeof(ss); i++){
* * * * us[i] = ss[i];
* * }
Нет ли путей короче? Нигде так и не нашёл ответа, просьба помочь.
Как создать функцию, в которую можно передать массив неограниченной размерности? Хм...боюсь Вас расстроить, но этого нельзя сделать НИКАК. потому что массивов неограниченной размерности не бывает в природе. Разработчики языка С++ подумали и решили не делать таких массивов, я слышал, что это из за того, что у нас ограничена оперативная память и другие ресурсы компьютера)
Путей покороче тоже нет, потому что это логически целостный путь создания динамического двумерного массива, то есть, ты сначала создаёшь массив указателей и потом ты инициализируешь каждый указатель указателем.

Сама функция для работы с двумерным динамическим массивом будет примерно такая:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
double f(double **arr, int n) //Данная функция для квадратной матрицы.
{
    for(int i = 0; i < n; i++)
    {
         for(int j = 0; j < n; j++)
         {
               arr[i][j] = 0; //Обнуляем все элементы.
          }
    }
}
 
void main(){
  int n = 10;//Переменную можно запросить у пользователя.
  double **arr = new double*[n];
  for(int i = 0; i < n; i++)
  {
       arr[i] = new double[n];
  }
  f(arr, n);
}
Добавлено через 13 минут
P.S. Любой массив необходимо ограничить. Вопрос в том, что можно это сделать динамически (когда мы заранее не можем знать, какой размерности нам потребуется), либо ограничить непосредственно при разработке программы (например, если мы создаём массив символов и не хотим, что бы было больше 50 символов (например, строка для ввода пароля)). А если же Вы хотите воплотить в жизнь то, о чём я думаю, то вам необходимо каждый раз, при добавлении нового элемента в массив, проверять его на заполненность и если новый введённый символ выходит за границы массива, то неоходимо создать новый массив, который будет размерностью больше предыдущего и скопировать все значения из предыдущего массива в новый массив и потом добавить новый элемент в существующий массив. Впринципе всё легко и просто. Вот так можно приблизиться к "неограниченному массиву" )
0
alsav22
5426 / 4821 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
18.09.2012, 07:57 #7
Цитата Сообщение от Topotun Посмотреть сообщение
А если же Вы хотите воплотить в жизнь то, о чём я думаю, то вам необходимо каждый раз, при добавлении нового элемента в массив, проверять его на заполненность и если новый введённый символ выходит за границы массива, то неоходимо создать новый массив, который будет размерностью больше предыдущего и скопировать все значения из предыдущего массива в новый массив и потом добавить новый элемент в существующий массив. Впринципе всё легко и просто. Вот так можно приблизиться к "неограниченному массиву" )
Один из принципов С++ - облегчить повторное использование кода. Всё, о чём вы пишите, уже реализованно в STL. Брать и использовать. Классы с автоматическим управлением памятью.
0
18.09.2012, 07:57
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.09.2012, 07:57
Привет! Вот еще темы с ответами:

Работа с одномерным целочисленным массивом в функции - C++
Здравствуйте. Я написал несколько функций по работе с массивом. В dimentInt() я объявляю массив и передаю его в addNewElIDA, которая...

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

Функции для работы с одномерным динамическим массивом - C++
Написать функции для работы с одномерным динамическим массивом: 1. Заполнение массива случайными значениями. 2. Вывод элементов массива...

Написать функции для работы с динамическим массивом - C++
Дали вот эти задачи никак не могу решить, помогите. 1. Написать следующие функции для работы с динамическим массивом: a. Функция...


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

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

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