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

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

Войти
Регистрация
Восстановить пароль
 
maxon887
12 / 12 / 3
Регистрация: 05.06.2012
Сообщений: 280
#1

Добавление в бинарное дерево: почему используется указатель на указатель? - C++

25.12.2012, 02:16. Просмотров 747. Ответов 2
Метки нет (Все метки)

Здравствуйте,
Корень создаёться вот так
C++
1
TREE *root=NULL;
непонятно почему функия добовления использует указатель на указатель
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
void Add(TREE **current, int info)
 {
if(*current!=NULL) 
 { 
if(info<(*current)->info) 
 Add(&(*current)->left, info); 
else if(info>(*current)->info) 
 Add(&(*current)->right, info); 
else 
 (*current)->count++; 
 } 
else 
 { 
 *current= new TREE; 
 (*current)->info=info; 
 (*current)->left=NULL; 
 (*current)->right=NULL; 
 (*current)->count=1; 
 count++; 
 } 
 
 }
объясните плис
пример взят вот отсюда http://procpp.ru/laboratoriya-c-cpp/...vo-poiska.html

Добавлено через 2 минуты
пробовал написать вот так
C++
1
2
3
4
5
6
7
8
9
void Add(TREE *current,int info)
{
    if(*current==0) //если узел ещё не создан
    {
        сurrent=new TREE;
        current->info=info;
        current->left=0;
        current->right=0;
    }
не выделило память под рут
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.12.2012, 02:16
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Добавление в бинарное дерево: почему используется указатель на указатель? (C++):

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

Почему указатель на указатель объявляется как float **A; - C++
Почему float?

Как получить ссылку на указатель или указатель на указатель в массиве? - C++
В процессе реализации сортировки пузырьком натолкнулся на такую проблему: как поменять значения указателей, передаваемых в функцию. Если...

Для чего используется бинарное дерево? - C++
Подскажите, пожалуйста, для чего используется бинарное дерево? С какой целью? И если можно, пожалуйста, напишите простенький код с...

Используется потенциально неинициализированная локальная переменная-указатель - C++
// ex4.cpp: определяет точку входа для консольного приложения. // ...

Error C4703: используется потенциально неинициализированная локальная переменная-указатель - C++
// prog8.cpp: определяет точку входа для консольного приложения. #include &lt;stdio.h&gt; #include &lt;iostream&gt; #include &lt;string&gt; using...

2
Croessmah
Ушел
13783 / 8033 / 928
Регистрация: 27.09.2012
Сообщений: 19,803
Записей в блоге: 3
Завершенные тесты: 1
25.12.2012, 02:20 #2
Если Вы передадите просто указатель, то в функцию будет передана копия и все действия будут производится с ней.
В качестве примера:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
 
void foo1(int *p){
    p=NULL;
}
 
void foo2(int **p){
    *p=NULL;
}
 
int main(){
    int n;
    int *p=&n;
    std::cout<<p<<std::endl;
    foo1(p);
    std::cout<<p<<std::endl;
    foo2(&p);
    std::cout<<p<<std::endl;
    std::cin.get();
    return 0;
}
1
maxon887
12 / 12 / 3
Регистрация: 05.06.2012
Сообщений: 280
25.12.2012, 02:33  [ТС] #3
Спасибо, я кажеться дорубил)))
В качестве примера:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
 
void foo1(int *&p){
    p=NULL;
}
 
void foo2(int **p){
    *p=NULL;
}
 
int main(){
    int n;
    int *p=&n;
    std::cout<<p<<std::endl;
    foo1(p);
    std::cout<<p<<std::endl;
    foo2(&p);
    std::cout<<p<<std::endl;
    std::cin.get();
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.12.2012, 02:33
Привет! Вот еще темы с ответами:

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

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

Как правильно удалять выделенную память под указатель на указатель? - C++
есть код #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; using namespace std; void sort_1(const...

Зачем нужен указатель на указатель при работе с однонаправленным списком? - C++
День добрый. Столкнулся с непониманием этой темы. В частности, совершенно непонятен алгоритм инициализации такого вот списка. Например:...


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

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

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