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

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

Войти
Регистрация
Восстановить пароль
 
samohodkin
Сообщений: n/a
#1

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

19.11.2014, 20:28. Просмотров 220. Ответов 0
Метки нет (Все метки)

На вход подается описание бинарного дерева. На листьях (висячих вершинах) этого дерева написаны целые числа (от -106 до 106). Идем от корня дерева, случайно поварачивая направо или налево (с вероятностями 0.5).

Чему равно cреднее значение числа на листе, в который мы в конечном счете придем? Ответ вывести с точностью до двух знаков после запятой.

Грамматика дерева:

tree -> leaf

tree -> (tree tree)

leaf -> integer

Можно решить без дерева, т.к подаваться будет что-то типа: (21 32(1 1))

вот мое решение:
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
#include <iostream>
#include <stack>
#include <string>
#include <stdlib.h>
#include <ctype.h>
#include <cmath>
 
 
        using namespace std;
    int main() {
        
        string str, st;
 
        int index = 0, k = 0;
        double s = 0, res = 0;
        
        char chr;
        getline(cin, str);
 
        while (index < str.length())
        {
            chr = str[index];
 
            if ((chr != '(') && (chr != ')' && (chr != ' ')))
            {
                st = chr;
                k = atoi(st.c_str()); 
                res = res + k*pow(0.5, s);
            }
 
            if (chr == '(')
            {
                s = s + 1;
 
            }
            if (chr == ')')
            {
                s = s - 1;
 
            }
            
 
            index++;
        }
        cout << round(res * 100) / 100.;
        
    }
Только вот в моем решение k это всегда цифра, а оно должно быть числом, т.е для привеенного выше примера k=21;k=32,k=1. Никак не получается это реализовать. Помогите, пожалуйста.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.11.2014, 20:28     Бинарное дерево без дерева C++
Посмотрите здесь:

Бинарное Дерево(обход дерева) C++
C++ Бинарное дерево. Обход бинарного дерева (симметрический, прямой и обратный)
бинарное дерево C++
Бинарное дерево C++
C++ Бинарное дерево
Бинарное дерево С++ (функция проверки внутренних узлов дерева) C++
Бинарное дерево C++
C++ Бинарное дерево (передать адрес первого (корневого) элемента дерева в метод)
Бинарное дерево C++
Бинарное дерево, расчёт суммы элементов дерева C++
Постройте и выведите на экран бинарное дерево. Найдите произведение элементов дерева, находящихся на уровне u C++
Добавление нового элемента в бинарное дерево поиска с вспомогательной функцией(без рекурсии) C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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