С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/25: Рейтинг темы: голосов - 25, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 23.11.2014
Сообщений: 20
Записей в блоге: 2
1

Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру

29.03.2015, 00:29. Показов 5066. Ответов 2
Метки нет (Все метки)

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

вот выход:
Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру

вот как подается входной файл:
Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру

Узел 10 является листом, поэтому чтобы обозначить это во входном файле указывается, что оба его потенциальных потомки отсутствуют - после 10 идет два нуля (0 0). Далее в файле идет еще один 0, который указывает на отсутствие правого потомка для узла 6.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.03.2015, 00:29
Ответы с готовыми решениями:

Преобразовать идеальное бинарное дерево в бинарное дерево поиска
Всем привет, я создал идельное бинарное дерево и написал к нему функции. Как мне теперь можно...

Данные из массива структур Date передать в бинарное дерево поиска и вывести его при помощи обратного обхода
Доброго времени суток! Задание:Данные из массива структур Date передать в бинарное дерево поиска и...

Бинарное дерево. Ссылка на структуру
Строю бинарное дерево. Узлы - структуры. Сортировка будет по номеру рейса. Как сделать ссылку на...

Бинарное дерево поиска
Дали такую задачу: Дан набор попарно не равных целых чисел, по ним строится бинарное дерево...

2
_Ivana
29.03.2015, 14:54
  #2

Не по теме:

Haskell
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
data Tree a = Z | N (Tree a) a (Tree a) deriving Show
 
l2t = fst . go where
    go []     = (Z, [])
    go (0:xs) = (Z, xs)
    go (x:xs) = (N l x r, xr) where (l,xl) = go xs; (r,xr) = go xl
 
t2l Z         = [0]
t2l (N l a r) = a : t2l l ++ t2l r
 
lftCnt Z         = Z
lftCnt (N l a r) = N (lftCnt l) (leaves l) (lftCnt r) where
    leaves Z         = 0
    leaves (N l a r) = 1 + leaves l + leaves r
 
bld _ Z         = Z
bld v (N l a r) = N (bld vl l) (head vr) (bld (tail vr) r) where (vl, vr) = splitAt a v
 
res l = t2l . bld (sort . filter (/=0) $ l) . lftCnt . l2t $ l
 
main = print $ res [1,4,6,10,0,0,0,7,0,8,0,0,2,5,0,0,3,9,0,0,0]
[6,3,2,1,0,0,0,4,0,5,0,0,8,7,0,0,10,9,0,0,0]

Небольшой апдейт - считать количество листьев лучше сразу при построении дерева, а не потом пробегаясь по нему снова. И кот короче.
Haskell
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
data Tree a = Z | N (Tree a) a (Tree a) deriving Show
 
l2t = (\(t,_,_) -> t) . go where
    go (0:xs) = (Z, xs, 0)
    go (x:xs) = (N l nl r, xr, nl+nr+1) where (l,xl,nl) = go xs; (r,xr,nr) = go xl
 
t2l Z         = [0]
t2l (N l a r) = a : t2l l ++ t2l r
 
bld _ Z         = Z
bld v (N l a r) = N (bld vl l) h (bld vr r) where (vl, h:vr) = splitAt a v
 
res l = t2l . bld (sort . filter (/=0) $ l) . l2t $ l
 
main = print $ res [1,4,6,10,0,0,0,7,0,8,0,0,2,5,0,0,3,9,0,0,0]

0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
33019 / 21321 / 8184
Регистрация: 22.10.2011
Сообщений: 36,620
Записей в блоге: 9
30.03.2015, 10:23 3
Евгений2395, здесь было: http://www.geeksforgeeks.org/b... onversion/
0
30.03.2015, 10:23
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.03.2015, 10:23
Помогаю со студенческими работами здесь

Бинарное дерево поиска
Напечатать элементы дерева с указанием их уровня в порядке возрастания уровней

Бинарное дерево поиска
#include "iostream" #include "math.h" #include "windows.h" using namespace std; struct Node {...

Бинарное дерево поиска
Необходимо реализовать структуру данных "бинарное дерево поиска" для целых чисел без балансировки....

Бинарное дерево поиска C++
+Доброго времени суток! У меня есть задание:создать картотеку,в ней указать тип магазина,номер...

Бинарное дерево поиска
Вот задали лабораторною работу. Сделал бинарное дерево поиска. Выдает ошибку "Что послан сигнал от...

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru