0 / 0 / 0
Регистрация: 26.12.2015
Сообщений: 15
1

Зачем нужен указатель на указатель при работе с однонаправленным списком?

19.03.2016, 16:24. Показов 2540. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
День добрый. Столкнулся с непониманием этой темы. В частности, совершенно непонятен алгоритм инициализации такого вот списка. Например:
C++
1
2
3
4
5
6
7
8
9
10
11
12
//создание однонаправленного списка (добавления в конец)
void Make_Single_List(int n,Single_List** Head){
  if (n > 0) {
    (*Head) = new Single_List();
    //выделяем память под новый элемент
    cout << "Введите значение ";
    cin >> (*Head)->Data;
    //вводим значение информационного поля
    (*Head)->Next=NULL;//обнуление адресного поля
     Make_Single_List(n-1,&((*Head)->Next));
  }
}
Не понимаю, почему передаем в функцию именно двойной указатель на структуру? Почему нельзя передать просто указатель *Head и работать с ним? И почему потом в рекурсии передаем указатель *Head по ссылке? Был бы очень признателен, если кто-то мог прояснить эти моменты.

Добавлено через 1 час 18 минут
Только написал и, кажется, наконец-таки таки нашел ответ. **Head - используется для передачи указателя *Head по ссылке. То есть, если мы хотим изменить нашу структуру, как в этом случае, добавив к ней еще элементы, мы должны передать ей эл-т по ссылке. Вот только как-то интересно получается... Ведь если мы передаем по указателю в функцию обычную переменную, она уже должна меняться, для того и передаем по указателю, собственно. Почему тогда структура таким образом не изменяется? Это конкретная особенность структур? Если так, то и на второй вопрос ответ ясен.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.03.2016, 16:24
Ответы с готовыми решениями:

Реализация двоичных деревьев поиска: Зачем в параметрах функции используется указатель на указатель
Всем привет, встретил в книге такой пример добавления узла в дерево: typedef struct tree {...

Зачем нужен динамическому массиву указатель?
1) Зачем когда обьявляем массив нужен указатель? 2) почему если массив передаётся в функцию нужен...

Зачем использовать Указатель на указатель?
Подскажите зачем использовать Указатель на указатель? И как работают двумерные массивы за счет...

Как получить ссылку на указатель или указатель на указатель в массиве?
В процессе реализации сортировки пузырьком натолкнулся на такую проблему: как поменять значения...

2
1943 / 1768 / 825
Регистрация: 23.01.2014
Сообщений: 6,230
20.03.2016, 09:44 2
Цитата Сообщение от h0las_qq Посмотреть сообщение
Не понимаю, почему передаем в функцию именно двойной указатель на структуру?
У Вас надо спросить наверное Такими же успехами можете и тройной указатель передавать и пятерной. И обращаться как (*(*(*(*Head))))->Data.
0
0 / 0 / 0
Регистрация: 26.12.2015
Сообщений: 15
22.03.2016, 12:44  [ТС] 3
Более-менее разобрался, спасибо
0
22.03.2016, 12:44
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.03.2016, 12:44
Помогаю со студенческими работами здесь

Ошибка при работе с указателем на указатель
Пытаюсь разобраться с указателем на указатель. // ConsoleApplication3.cpp: определяет точку входа...

При работе fstream указатель типа pos_type (позиции в файле) не работает
Разбираю код с сайта: http://valera.asf.ru/cpp/book/c20.html Компилятор Билдер-6 ругается. когда...

Функция, получающая указатель на обычную функцию, получает указатель на метод класса
Здравтсвуйте. Имеется вопрос по указателям на методы класса. Допустим, есть функция( f ), которая...

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru