Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.81/75: Рейтинг темы: голосов - 75, средняя оценка - 4.81
 Аватар для amfisat
70 / 70 / 36
Регистрация: 16.06.2009
Сообщений: 240

Печать листьев бинарного дерева

24.08.2012, 10:29. Показов 15286. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!

Решаю такую задачу:
На входе - последовательность целых чисел, оканчивающаяся 0, который является символом завершения ввода. Надо построить бинарное дерево и вывести на печать все его листья (узлы без детей) в возрастающем порядке.

Код написан, но все тесты программа не проходит.

Кому не очень лень, посмотрите, пожалуйста, и скажите, где криво или подскажите, на каких примерно тестах валится программа.

Код
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
#include <iostream>
 
using namespace std;
 
struct node //узел
{
    int val;
    node *left, *right;
    node(): val(0) {};
};
 
node *addNode (int val)
{
    node *nnode = new node[sizeof(node)];
    nnode->left = NULL;
    nnode->right = NULL;
    nnode->val = val;
    return nnode;
}
 
node *addTree (node *root, int val)
{
    if (root == NULL)
        root = addNode (val);
    if (val > root->val)
        if (root->right == NULL)
            root->right = addNode (val);
        else
            addTree (root->right, val);
    if (val < root->val)
        if (root->left == NULL)
            root->left = addNode (val);
        else
            addTree (root->left, val);
    return root;
 
}
 
void printLeafs (node *root)
{
    if (root != NULL)
    {
        printLeafs (root->left);
        if (root->left == NULL && root->right == NULL)
            cout << root->val << endl;
        printLeafs (root->right);
    }
}
 
int main()
{
    freopen ("input.txt", "r", stdin);
    freopen ("output.txt", "w", stdout);
    int n;
    cin >> n;
    node *tree = new node;
    tree = NULL;
    if (n != 0)
        tree = addNode (n);
    while (n != 0)
    {
        addTree (tree, n);
        cin >> n;
    }
    printLeafs (tree);
    return 0;
}


Всем спасибо.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.08.2012, 10:29
Ответы с готовыми решениями:

Функция вывода листьев бинарного дерева
Написал функцию вывода всего что есть в дереве. помогите переделать ее так чтобы она выводила только листья(без детей которые) void...

Вывод списка всех листьев бинарного дерева поиска
Нужно реализовать бинарное дерево поиска и вывести все его вершины, не имеющие потомков. Само дерево реализовано вот так struct node...

Вывести разность значений всех листьев бинарного дерева
Дан указатель P1 на корень непустого дерева. Вывести разность значений всех листьев данного дерева. что делать в этом задании?

4
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
24.08.2012, 10:45
Цитата Сообщение от amfisat Посмотреть сообщение
Код написан, но все тесты программа не проходит.
ссылку на задачу можете дать?
0
 Аватар для amfisat
70 / 70 / 36
Регистрация: 16.06.2009
Сообщений: 240
24.08.2012, 11:16  [ТС]
Вот
У меня проходит 52 теста из 60.
А здесь - вообще ни одного (задача - та же самая).

Добавлено через 19 минут
Нет, вру: по 2 ссылке проходит 4 теста из 20.
0
154 / 138 / 34
Регистрация: 23.05.2009
Сообщений: 275
24.08.2012, 12:06
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
#include <iostream>
 
using std::cout;
using std::cin;
using std::endl;
 
struct node
{
    int val;
    node *left, *right;
    node(int i): val(i), left(NULL), right(NULL) {};
};
 
node *addNode(int val)
{
    return new node(val);
}
 
node *addTree(node *root, int val)
{
    if (!root)
    {
        root = addNode(val);
        return root;
    }
    if (val < root->val)
    {
        if (!root->left)
        {
            root->left = addNode(val);
        }
        else
        {
            addTree(root->left, val);
        }
    }
    if (val > root->val)
    {
        if (!root->right)
        {
            root->right = addNode(val);
        }
        else
        {
            addTree(root->right, val);
        }
    }
    return root;
 
}
 
void printLeafs (node *root)
{
    if (root)
    {
        printLeafs(root->left);
        if (!root->left && !root->right)
            cout << root->val << endl;
        printLeafs(root->right);
    }
}
 
int main()
{
    int num = 0;
    cin>>num;
    node *tree = NULL;
    if (num != 0) 
        tree = new node(num);
    while(num != 0)
    {
        addTree(tree, num);
        cin>>num;
    }
    printLeafs(tree);
    return 0;
}
тест по ссылкам я увидел только один, может быть потому что я там не зарегистрирован:
Входные данные: 7 3 2 1 9 5 4 6 8 0
Выходные данные: 1 4 6 8
Данный тест пройден.
1
 Аватар для amfisat
70 / 70 / 36
Регистрация: 16.06.2009
Сообщений: 240
24.08.2012, 13:45  [ТС]
Всё, отбой, ошибка нашлась: она была в функции создании дерева.

Andsteadur, спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.08.2012, 13:45
Помогаю со студенческими работами здесь

Запись бинарного дерева в файл и восстановление из него этого дерева
Задача такая: есть бинарное дерево. Каждый элемент дерева содержит 3 указателя - 1 указатель на структуру с данными, 2 и 3й указатель на...

Написать шаблон бинарного дерева с функцией распечатки дерева
Не понимаю, что от меня хотят. Дано такое задание: Написать шаблон бинарного дерева с функцией распечатки дерева *(+(d,e),c) в виде...

Построение бинарного дерева на основе не бинарного
В лабораторной работе есть такое задание: Создайте процедуру построения бинарного дерева на основе не бинарного. Объясните как вообще...

Создание бинарного дерева из бинарного файла
struct Bin { string name; string city; int players; int score; }; void ReadFromBin(Point*&amp; Tree) { Bin q;

Определить число листьев на каждом уровне дерева
Нужно составить такую функцию. Именно на каждом отдельном уровне, а не по дереву вообще.


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru