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

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

Войти
Регистрация
Восстановить пароль
 
nik.basket
0 / 0 / 0
Регистрация: 15.01.2011
Сообщений: 3
#1

Бинарное дерево - C++

15.01.2011, 23:37. Просмотров 426. Ответов 0
Метки нет (Все метки)

надо создать бинарное дерево и найти среднее арифметическое всех четных чисел!!!

Добавлено через 9 минут
типа вот такой фигни


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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
//---------------------------------------------------------------------------
//Построить двоичное дерево поиска. Определить два максимальных элемента
#include <vcl.h>
#pragma hdrstop
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
 
//---------------------------------------------------------------------------
 
#pragma argsused
struct TREE
{
    int d;
 
    TREE *left;
    TREE *right;
    TREE *first(int d);
    TREE *fun(TREE*root, int d);
    void print(TREE *root, int l);
    void poisk_max(TREE *ptr, int& max1, int& max2);
};
 
TREE*first(int d)
{
    TREE *pv = new TREE;
    pv->d = d;
    pv->left = 0;
    pv->right = 0;
    return pv;
}
TREE *fun(TREE *root, int d)
{
    TREE*pv = root, *prev;
    int found = 0;
    while (pv && !found)
    {
        prev = pv;
        if (d == pv->d)
            found = 1;
        else if (d < pv->d)
            pv = pv->left;
        else
            pv = pv->right;
 
    }
    if (found)
        return pv;
    // Создание нового узла
 
    TREE *pnew = new TREE;
    pnew->d = d;
    pnew->left = 0;
    pnew->right = 0;
    if (d < prev->d)
        prev->left = pnew; //присоединяет к левому поддереву
    else
        prev->right = pnew; //присоединяет к правому поддереву
    return pnew;
}
 
void print(TREE *p, int level)
{
    if (p)
    {
        print(p->left, level + 1); //левое
        //cout<<"\n glubina: "<<level;
 
        for (int i = 0; i <= level; i++)
 
            cout << " ";
 
        cout << p->d << endl; //вывод правого поддерева
        print(p->right, level + 1);
    }
}
 
void poisk_max(TREE *ptr, int& max1, int& max2)
{
    if (ptr)
    {
        if (ptr->d > max1)
            max1 = ptr->d;
        poisk_max(ptr->right, max1, max2);
        poisk_max(ptr->left, max1, max2);
    }
 
    if (ptr)
    {
        if ((ptr->d > max2) && (ptr->d < max1))
            max2 = ptr->d;
        poisk_max(ptr->right, max1, max2);
        poisk_max(ptr->left, max1, max2);
    }
}
 
int main()
{
    int n;
    int *b;
    cout << "Vvedite kolichestvo elenentov ";
    cin >> n;
 
    b = new int[n];
 
    cout << "Vvedite massiv \n";
    for (int i = 0; i < n; i++)
        cin >> b[i];
    cout << endl;
 
    TREE *root = first(b[0]);
 
    for (int i = 0; i < n; i++)
        fun(root, b[i]);
    getchar();
    print(root, 0);
    getchar();
 
    int max1 = b[0];
    int max2 = b[1];
 
    poisk_max(root, max1, max2);
    cout << "\n Max1:" << max1 << " Max2: " << max2;
    getch();
    return 0;
 
}
но здесь находятся 2 максимальных числа а мне надо найти среднее арифметическое всех четных чисел
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.01.2011, 23:37
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Бинарное дерево (C++):

Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру - C++
Помогите, не могу понять!( Нужно исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру. вот...

Бинарное дерево. Удалить из дерева часть вершин так, чтобы оставшееся дерево стало пирамидой - C++
Дано бинарное дерево. Удалить из дерева часть вершин так, чтобы оставшееся дерево стало пирамидой.

Бинарное дерево - C++
Как организовать вывод бинарного дерева?

Бинарное дерево - C++
Объясните пжлст почему не работает программа...при вводе файла пишет -842150451 /*Дан адрес P1 вершины дерева — записи типа TNode, ...

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

Бинарное дерево - C++
Здравствуйте, нужно помощь в написании программы. Условие: Каждая вершина бинарного дерева содержит: - 2 указателя (на каждый...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.01.2011, 23:37
Привет! Вот еще темы с ответами:

Бинарное дерево - C++
Нужно записать в дерево и вывести в форматированном виде каталог файлов(типа windows) на вход даны имена файлов вида c:\win\1 ...

Бинарное дерево - C++
Разработать и реализовать на языке С следующие функции работой с бинарным деревом: 1. Создание пустого дерева 2. Добавление элемента в...

Бинарное дерево - C++
Здравствуйте, Корень создаёться вот так TREE *root=NULL; непонятно почему функия добовления использует указатель на указатель ...

Бинарное дерево - C++
Помогите, пожалуйста. Осталась последняя задача в контрольной. Не знаю даже, как к ней подступиться. К проекту ПРИМЕР Btree ...


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

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

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