Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/58: Рейтинг темы: голосов - 58, средняя оценка - 4.97
1 / 1 / 0
Регистрация: 03.06.2009
Сообщений: 5

генеалогическое дерево на C++

17.06.2009, 13:03. Показов 12145. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста с утра сижу использую бинарное дерево.Не получаеться с вводом когда вожу например Bogdan1990 прога разбивает это на отдельные элементы потом переделал выдает ошибку.Вот задание :Разработать программу, формирующую динамическую структуру данных для хранения генеалогического дерева. Каждая вершина дерева должна содержать следующую информацию: имя и год рождения.
Помогите кому не сложно
вот мой набросок:
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
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
using namespace std;
//описание дерева 
struct tree {
        char str[15];   
       tree *leftchild;
       tree *rightchild;
       tree *parent;
        } ;
tree *root,*curr;
 
//инициализация данных
void tree_init(void)
{
root=(tree *) new tree;
root->str='Bogdan1990';
root->rightchild=NULL;
root->leftchild=NULL;
root->parent=NULL;
curr=root;
}
//добавление узлов в левую ветвь дерева
void add_tree_left(char ins[15])
{
tree *newT=(tree *) new tree;
newT->str=ins;
newT->rightchild=NULL;
newT->leftchild=NULL;
newT->parent=curr;
curr->leftchild=newT;
curr=newT;
}
//добавление узлов в правую ветвь дерева
void add_tree_right(char ins[15])
{
tree *newT=(tree *)new tree;
newT->str=ins;
newT->rightchild=NULL;
newT->leftchild=NULL;
newT->parent=curr;
curr->rightchild=newT;
curr=newT;
}
//вывод на экран элементов дерева,
void tree_print(tree *c)
{
if (c!=NULL) {
             tree_print(c->leftchild);
         if (c==curr) {cout<<c->str;} else {cout << " "<<c->str<<" ";c->str;};
             tree_print(c->rightchild);
         }
}
 
//главная процедура
int main()
{
 
char tmp[15];int d;
do {
    printf("\n========================\n1-add_tree_left;\n2-add_tree_right;\n3-tree_print;\n");
   scanf("%d", &d);
   if (d==1) {cout<<"Vvedite element: ";cin>>tmp;add_tree_left(tmp);};
   if (d==2) {cout<<"Vvedite element: ";cin>>tmp;add_tree_right(tmp);};
   if (d==3) {tree_print(root);};
   } while (d!=0);
return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.06.2009, 13:03
Ответы с готовыми решениями:

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

Дано дерево. Распечатать дерево по уровням
Дано дерево. Распечатать дерево по уровням.

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

1
shiev
26.11.2009, 14:47
есть такая штука STL
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <map>
#include <string>
using namespace std;
struct value_t
{
...
};
struct node_t
{
value_t _value;
map<string,node_t> _node
};
main()
{
node_t node_child; 
node_t node_root; 
node_root._node.insert(make_pair(''потомок",node_child));
node_root._node[''потомок"].insert(make_pair(''потомок",node_child));
}
получается дерево любого уровня вложенности.
понятно это принцип. Детали реализации могут быть разные.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.11.2009, 14:47
Помогаю со студенческими работами здесь

Напишите программу, которая бы читала дерево в формате (а) и затем печатала бы это дерево в формате (б).
Представление дерева: а) Д (Б (А, Ф (В,)), Е (,З (Ж, И))) б) Д Б А Ф ...

Генеалогическое дерево
Подскажите пожалуйста с помощью чего сделать вывод информации и соединять по родству??? Может есть исходник для примера???

Генеалогическое дерево
Всем добрый вечер(утро,день,ночь) Есть задание : Реализовать Генеалогическое дерево. Паспортные данные членов некоторого родового...

Генеалогическое дерево
Подскажите пожалуйста с помощью чего сделать вывод информации и соединять по родству??? Может есть исходник для примера???

Генеалогическое дерево на Python3
Хочу написать в ближайшей перспективе программу на Python3 семейное гинеалогическое дерево. Типа семеного альбома + текстовая информация. ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru