|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
Бинарные деревья. Составить программу, которая содержит информацию о книгах в библиотеке.08.11.2018, 16:18. Показов 5326. Ответов 19
Метки нет (Все метки)
Здравствуйте. Учусь в универе. Задали написать вот такую программу. А я с бинарными деревьями никогда не работал. Помогите кто может
Составить программу, которая содержит информацию о книгах в библиотеке. Сведения о книгах содержат: 1. Номер УДК 2. Фамилия и инициалы автора; 3. Название; 4. Год издания; 5. Количество экземпляров данной книги в библиотеке. Программа должна обеспечивать: 1. Исходное формирования данных о все книгах в библиотеке в виде бинарного дерева; 2. Добавление данных о книгах, впервые поступающих в библиотеку; 3. Удаление данных о списанных книги; 4. Проверить, бинарное дерево является сбалансированным.
0
|
|
| 08.11.2018, 16:18 | |
|
Ответы с готовыми решениями:
19
Составить программу, которая содержит текущую информацию о книгах в библиотеке Составить программу, которая содержит текущую информацию о книгах в библиотеке |
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
||
| 08.11.2018, 16:30 | ||
|
DragonBorn88, здравствуйте! По какому принципу происходит добавление? То есть, как мы будем определять, что книга впервые поступила в библиотеку? По какому принципу происходит списание? Я могу пока сделать добавление данных в дерево. Но мне нужно больше информации. Откуда добавляются данные? Из текстового файла?
Добавлено через 3 минуты DragonBorn88, еще один вопрос. Это должно быть бинарное дерево поиска или просто бинарное дерево? Добавлено через 2 минуты
0
|
||
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
||||||
| 08.11.2018, 18:32 [ТС] | ||||||
|
Просто бинарное дерево. Добавление с клавиатуры.
Вот я нашел код, но выбивает ошибки. Посмотрите, может ошибку сможете найти
0
|
||||||
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
||||||
| 08.11.2018, 21:04 | ||||||
|
DragonBorn88, пока удалось добавить записи в дерево и вывести по заданному полю:
Добавлено через 11 минут DragonBorn88, почему вы не хотите использовать бинарное дерево поиска? Это позволит избежать повторов при добавлении и выводить данные в отсортированном порядке (по любому полю).
0
|
||||||
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
| 08.11.2018, 22:35 [ТС] | |
|
Устроит полностью.
Можете использовать поиска. Я думал так будет проще.
0
|
|
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|||||||||||
| 09.11.2018, 23:09 | |||||||||||
|
DragonBorn88, здравствуйте! Я структуры в деревья так еще ни разу не добавлял. Вот тестовый вариант того, что получилось. Посмотрите. Может быть, вам подойдет. Поля записи обязательно без пробелов!
Пример входных данных (файл db.txt):
0
|
|||||||||||
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|
| 10.11.2018, 11:44 | |
|
DragonBorn88, отпишитесь, пожалуйста. Вас устраивает такой вариант?
0
|
|
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
| 10.11.2018, 20:31 [ТС] | |
|
У меня возникла вот такая ошибка. Что я делаю не правильно?
0
|
|
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
||||||
| 11.11.2018, 00:51 | ||||||
|
DragonBorn88, здравствуйте! Специально запускал проект в MS Visual Studio 2017. Есть небольшие отличия в компиляторах. Вот код, который скомпилировался и работает:
0
|
||||||
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
| 11.11.2018, 12:09 [ТС] | |
|
Всё работает красиво.
Сделайте ещё пожалуйста что бы содержимое db.txt выводилось в консоли
0
|
|
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
| 11.11.2018, 12:28 [ТС] | |
|
На экран я смог вывести файл txt.
Почему программа пишет что дерево не сбалансировано? Как я понимаю это не очень хорошо? Или это не существенно?
0
|
|
|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|||||||||||
| 11.11.2018, 16:04 | |||||||||||
Сообщение было отмечено DragonBorn88 как решение
Решение
DragonBorn88, здравствуйте! Вам нужно посмотреть определение сбалансированности бинарного дерева поиска. Дерево называется сбалансированным, если высота левого поддерева отличается от высоты правого не более чем на 1 и наоборот. Если никакие элементы в дерево еще не добавлялись, то программа скажет, что дерево сбалансировано (по определению пустое дерево всегда сбалансировано). Все зависит от id книги. По id узлы добавляются в дерево. Вам все еще нужна функция вывода узлов дерева на экран?
Для примера введите эти данные (удалите все старые узлы из файла или сам файл):
А теперь, удалите узел с id = 57894. Снова вернитесь в меню и нажмите 3 - дерево стало сбалансированным после удаления узла с id 57894. Добавлено через 29 минут DragonBorn88, добавил функцию печати файла db.txt на экран. Вот итоговый код:
0
|
|||||||||||
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
| 11.11.2018, 16:40 [ТС] | |
|
Огромное вам спасибо
0
|
|
|
Комп_Оратор)
|
|||||||||
| 11.11.2018, 18:48 | |||||||||
|
2. Хуже всего, что не Вы ни Ваш университет не понимаете, что балансировка дерева с повторениями, это грустная тема. Если оно не оформлено как map - то есть для пар ключ/значение, где ключи уникальны, а значение - количество. Этот приём позволяет избежать повторов на уровне структуры дерева скрыв их в данных узла (нода). В задании забыли написать, что человеку, который (по ряду разнообразных обстоятельств неотвратимой силы) Поэтому вот такой код, вполне мог бы прокатить за отмазку:
0
|
|||||||||
|
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
|
|
| 11.11.2018, 19:17 [ТС] | |
|
Ваш код мне выдаёт вот такие ошибки:
0
|
|
|
Комп_Оратор)
|
|||||||
| 11.11.2018, 19:31 | |||||||
Хотя к функтору-предикату это не может иметь отношения, кажется.
0
|
|||||||
|
|
|
| 11.11.2018, 19:32 | |
|
IGPIGP, ну и чему такому научит ваш код? Что существует std::map? Спасибо, для этого справка есть.
А задание учит человека самостоятельно проектировать сложные структуры данных типа деревьев.
0
|
|
|
Комп_Оратор)
|
|||||||||
| 11.11.2018, 20:14 | |||||||||
|
Задание написать само-балансирующееся дерево и требование хранить тип данных : тюбетейка, с полями: цвет, узор, вышитые инициалы и т.п. Мне показалось, туповатым (мягко говорю). Мы отличаемся тем, что Вам оно кажется нормальным. А как на счёт балансировки дерева с повторениями? Моё замечание насчёт пар ключ/значение тоже непонятно? Не по теме: И наконец. Даже без обёртки мапа в этой задаче заняла объём хорошей лабы. А если писать дерево - курсовая. Я не хочу это даже комментировать. Добавлено через 32 минуты DragonBorn88, Вы молчите и я попытаюсь дать ещё совет наугад: попробуйте закоментить конст в объявлении итераторов карты:
0
|
|||||||||
|
|
|
| 11.11.2018, 21:05 | |
|
IGPIGP, то что в ВУЗах наших за курсовую считается написание банального самобалансирующегося дерева - это бич нашего образования. Какой-нибудь конструктор Яковлев или Ильюшин во время учёбы в ВУЗе свой первый самолёт создавал, а тут блин, дерево запрограммировать, ну да, не только дерево, ещё и АВЛ-балансирующееся, ещё и обвязать его интерфейсом мапы... всё равно не тянет на научный труд даже уровня курсовой. Самолёт, блин(!!!) и какое-то дерево по и без того подробно описанным в интернете и книгах принципам.
1
|
|
|
Комп_Оратор)
|
|||
| 11.11.2018, 21:29 | |||
"Разработать биплан грузоподъёмностью 800 кг полезной нагрузки, предусмотрев возможность перевозки 4 голов крупного рогатого скота, различной степени упитанности и удойности, 5-6 мешков корнеплодов, весом до 80 кг, каждый и т.п.". То есть при чём, выбор общей конфигурации корпуса, силовой установки, дальности полёта, взлётно-посадочных характеристик и пр. базовых параметров, к конкретизации грузового отсека? Меня удивило это условие.
1
|
|||
| 11.11.2018, 21:29 | |
|
Помогаю со студенческими работами здесь
20
Составить программу, которая содержит текущую информацию о книгах в библиотеке Динамические структуры данных. Составить программу, которая содержит текущую информацию о книгах в библиотеке Составить программу, которая содержит текущую информацию о книгах Составить программу, которая содержит текущую информацию о книгах в библиотеке Разработать программу, которая содержит текущую информацию о книгах в библиотеке. Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|