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

Высота n-нарного дерева

02.04.2011, 21:36. Показов 2226. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите алгоритм нахождения высоты n-нарного дерева, я написала, но высота находится не всегда точно. Не знаю как избежать этого.
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
struct tree
    {
        int k; //элемент дерева
        int kol_child; //количество потомков
        tree **child;
    };
    tree *root=NULL; //корень дерева
    int *n=new int[5]; //допустим пять ветвей в дереве
    for (int i=0;i<5;i++)
        n[i]=0;
    cout<<visota_root(root,n,0);
 
int visota_root (tree *p,int *n,int i)
{
    if  (!p) 
        return (0); 
    else
    {   
        for (i=0;i<p->kol_child;i++)
                n[i]=visota_root(p->child[i],n,i);
        if (n[i]>=n[0])
            return (n[i]+1);
        else
            return (n[0]+1);
 
    }       
}
Добавлено через 12 минут
еще вот так пробовала, но безполезно:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int visota (tree *p,tree *p_root,int n,int m) 
{
    if  (!p) 
        return (0); 
    else
    {   
        for (int i=0;i<p->kol_child;i++)
        {
            m=i+1;
            n=visota(p->child[i],p_root,n,m);
        }
        if (p==p_root || m==1 || n==0)
            return (n+1);
        else 
            return (n);
    }       
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.04.2011, 21:36
Ответы с готовыми решениями:

Высота бинарного дерева
Надо найти высоту бинарного дерева.

Высота авл дерева - как считать?
Добрый вечер. Забавно. Предположим, что пустой указатель равен -1, высота пр - высота лев. А как посчитать высоту авл дерева с...

Высота бинарного дерева поиска
Что неправильно в программе? Полное условие #include &lt;iostream&gt; #include &lt;cstdio&gt; #pragma comment (linker,...

1
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
03.04.2011, 01:05
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
/////////////////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <iostream>
#include <vector>
/////////////////////////////////////////////////////////////////////////////////////////
template<size_t  N>
struct  T_node
{
    static const size_t  CHILDREN_TOTAL_MAX = N;
    //-----------------------------------------------------------------------------------
    typedef std::vector<T_node<N>*>  T_p_children;
    //-----------------------------------------------------------------------------------
    int           val_;
    T_p_children  p_children_;
    //-----------------------------------------------------------------------------------
    T_node(int  val) 
        : val_         (val),
          p_children_  (CHILDREN_TOTAL_MAX, 0)
    {}
    //-----------------------------------------------------------------------------------
    bool  add_child(T_node&  node)
    {
        T_p_children::iterator  zero_p_it 
            = std::find(p_children_.begin(), p_children_.end(), static_cast<T_node<N>*>(0));    
        bool  bool_res = zero_p_it != p_children_.end();
        if(bool_res)
        {
            *zero_p_it = &node;
        }
        return  bool_res; 
    }
    //-----------------------------------------------------------------------------------
    size_t  tree_height()
    {
        size_t  child_heght_max = 0;
        for(T_p_children::iterator  p_child_it = p_children_.begin();
            p_child_it != p_children_.end(); ++p_child_it)
        {
            if(*p_child_it == 0) continue;
            size_t  cur_child_heght = (*p_child_it)->tree_height();
            if(cur_child_heght > child_heght_max)
            {
                child_heght_max = cur_child_heght;
            }
        }
        return  1 + child_heght_max;
    }
};
/////////////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::locale::global(std::locale(""));
    typedef T_node<4>  T_node_4;
    T_node_4  tree(1);
    T_node_4  a(2);
    T_node_4  b(3);
    T_node_4  c(4);
    T_node_4  d(5);
 
    std::cout << "Высота дерева равна "
              << tree.tree_height()
              << "."
              << std::endl;
 
    tree.add_child(a);   
    tree.add_child(b);    
 
    std::cout << "Высота дерева равна "
              << tree.tree_height()
              << "."
              << std::endl;
 
    a.add_child(c);
    a.add_child(d);
 
    std::cout << "Высота дерева равна "
              << tree.tree_height()
              << "."
              << std::endl;
}
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.04.2011, 01:05
Помогаю со студенческими работами здесь

Чему приближённо равняется высота дерева
Длина тени, которую отбрасывает столб высотой 5 м в определенный момент времени, равна 3 м. Чему приближённо равняется высота дерева, если...

Высота вершины Бинарного Поискового Дерева
Как при помощи обратного обхода расставить метки высот вершин?

Бинарные деревья, глубина (высота) дерева
Есть дерево, состоящее из целых чисел , читаемых из файла. С выводом и нахождением высоты дерева понятно. Как можно вывести все ветви,...

Определить, сколько полных метров и полных сантиметров составляет высота дерева.
Здравствуйте, решите, пожалуйста, задачу. Высота дерева k миллиметров. Определить, сколько полных метров и полных сантиметров составляет...

Одинаковая высота колонок при условии что высота изначально не известна
&lt;div class=&quot;row equal&quot;&gt; &lt;div class=&quot;col-md-8&quot;&gt; &lt;div...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru