Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.88/16: Рейтинг темы: голосов - 16, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 14.05.2019
Сообщений: 4
1

Построить дерево бинарного поиска и найти для него сумму нечетных значений узлов дерева

17.05.2019, 15:19. Просмотров 2951. Ответов 4
Метки нет (Все метки)

Ни как не могу придумать правильный метод который будет считать сумму нечетных значений узлов дерева.
Помогите пожалуйста!

u
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
128
129
130
131
132
133
sing System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
using System.IO; 
 
namespace ConsoleApp10 
{ 
public class BinaryTree 
{ 
public class Node 
{ 
 
public object inf; //информационное поле 
public Node left; //ссылка на левое поддерево 
public Node rigth; //ссылка на правое поддерево 
 
//конструктор вложенного класса, создает узел дерева 
public Node(object nodeInf) 
{ 
inf = nodeInf; 
left = null; 
rigth = null; 
} 
 
//добавляет узел в дерево так, чтобы дерево оставалось деревом бинарного поиска 
public static void Add(ref Node r, object nodeInf) 
{ 
if (r == null) 
{ 
r = new Node(nodeInf); 
} 
else 
{ 
if (((IComparable)(r.inf)).CompareTo(nodeInf) > 0) 
{ 
Add(ref r.left, nodeInf); 
} 
else 
{ 
Add(ref r.rigth, nodeInf); 
} 
} 
} 
 
public static void Preorder(Node r) //прямой обход дерева 
{ 
if (r != null) 
{ 
Console.Write("{0} ", r.inf); 
Preorder(r.left); 
Preorder(r.rigth); 
} 
} 
public static void total(Node t, int sum) 
{ 
if (t != null) //если узел не пустой 
{ 
if ((int)t.inf % 2 != 0) 
{ 
sum += (int)t.inf; 
} 
total(t.left, sum); 
total(t.rigth, sum); 
} 
} 
} 
 
 
Node tree; //ссылка на корень дерева 
//свойство позволяет получить доступ к значению информационного поля корня дерева 
public object Inf 
{ 
set 
{ 
tree.inf = value; 
} 
get 
{ 
return tree.inf; 
} 
} 
 
public BinaryTree() 
{ 
tree = null; 
} 
 
private BinaryTree(Node r) 
{ 
tree = r; 
} 
 
public void Add(object nodeInf) //добавление узла в дерево 
{ 
Node.Add(ref tree, nodeInf); 
} 
 
 
public void Preorder() 
{ 
Node.Preorder(tree); 
} 
public int total() 
{ 
int sum = 0; 
Node.total(tree, sum); 
return sum; 
} 
 
} 
 
class Program 
{ 
static void Main() 
{ 
int[] mas = new int[10]; 
BinaryTree tree = new BinaryTree(); 
using (StreamReader fileIn = new StreamReader("text.txt")) 
{ 
string line = fileIn.ReadToEnd(); 
string[] data = line.Split(' '); 
foreach (string item in data) 
{ 
tree.Add(int.Parse(item)); 
} 
} 
tree.Preorder(); 
Console.WriteLine(tree.total()); 
} 
} 
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.05.2019, 15:19
Ответы с готовыми решениями:

В дереве бинарного поиска найти для него количество четных значений узлов дерева
В файле input.txt хранится последовательность целых чисел. По входной последовательности построить...

Найти сумму значений узлов бинарного дерева, находящихся на нечетных уровнях
Помогите, пожалуйста с задачкой. :sorry: Найти сумму значений узлов бинарного дерева, находящихся...

В рабочей программе добавить для дерева бинарного поиска нахождение отрицательных значений узлов дерева
Полностью готовая программа, но что дописать в мейне чтобы он выводил произведение отрицательных...

Бинарные деревья. Вывод потомков для каждого из узлов бинарного дерева поиска
Здравствуйте, уважаемые форумчане! Продолжая изучать бинарные деревья, решил подумать о выгодности...

4
820 / 492 / 252
Регистрация: 26.11.2015
Сообщений: 1,559
Записей в блоге: 2
17.05.2019, 15:35 2
Лучший ответ Сообщение было отмечено Ksenia1232 как решение

Решение

C#
1
2
3
4
5
6
7
8
9
10
11
12
public static void total(Node t) 
{ 
    if (t != null) //если узел не пустой 
    { 
        if ((int)t.inf % 2 != 0) 
            return (int)t.inf + total(t.left) + total(t.right);
        else 
            return total(t.left) + total(t.right); 
    } 
    else
        return 0
}
Можно как то так.
1
0 / 0 / 0
Регистрация: 14.05.2019
Сообщений: 4
17.05.2019, 17:16  [ТС] 3
почему то пишет что не содержит определения для right: https://pp.userapi.com/c850428... 3Tu9no.jpg

и вот еще что: https://pp.userapi.com/c846016... JAcHp8.jpg

Добавлено через 2 минуты
2 ссылка не верная.
Вот верная: https://pp.userapi.com/c850428... zfsO_I.jpg
0
820 / 492 / 252
Регистрация: 26.11.2015
Сообщений: 1,559
Записей в блоге: 2
17.05.2019, 20:24 4
Лучший ответ Сообщение было отмечено Ksenia1232 как решение

Решение

1. У меня написано right, а у вас rigth.
2. Измените на
C#
1
public static int total(Node t)
1
0 / 0 / 0
Регистрация: 14.05.2019
Сообщений: 4
17.05.2019, 21:32  [ТС] 5
Все получилось.
Спасибо большое вам.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.05.2019, 21:32

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Монотонная последовательность узлов бинарного дерева поиска
Добрый день. есть бинарное дерево поиска и какое-то заданное число S. Нужно найти все монотонные...

Построить дерево бинарного поиска и найти глубину заданного узла
построить дерево бинарного поиска и найти глубину заданного узла


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

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

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