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

Бинарное дерево поиска с симметричным обходом по словам

18.05.2018, 23:15. Показов 2315. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер! Возникли трудности с реализацией задачи: слова вводятся пользователем, далее сортируются по длине и в алфавитном порядке (результат выводится). Необходимо определить те слова, длина которых больше задаваемой, и начинаются они с букв "a" и "b" (то есть, под "определение" попадают только те слова, которые содержат в начале указанные буквы, и при этом удовлетворяют введённой длине). Далее необходимо удалить эти слова и вывести оставшееся дерево.
Никак не могу собрать воедино требование с длиной и порядком следования слов, с теорией по деревьям ознакомлен (но, судя по сообщению, не полностью).
Спасибо сразу, что прочитали. Буду сердечно благодарен помощникам (можно и не просто сердечно))!
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.05.2018, 23:15
Ответы с готовыми решениями:

Бинарное дерево с прямым обходом c++
Здравствуйте. Как вывести корень дерева и, конкретно какой-то элемент из левой или правой ветви? Функция print. Хочу сделать что-то типо...

Бинарное дерево с прямым обходом
Нашел на просторах вашего форуме код дерева с восходящим порядком прохождения #include <iostream> #include <ctime> ...

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

1
 Аватар для NightSkyLark
21 / 21 / 22
Регистрация: 13.05.2018
Сообщений: 71
19.05.2018, 04:04
Лучший ответ Сообщение было отмечено SunUkolushko как решение

Решение

Цитата Сообщение от SunUkolushko Посмотреть сообщение
требование с длиной и порядком следования слов
Это можно поискать сортировку по двум полям.

Сравнивать слова по длине, а если длина слов одинаковая, то сравнивать в лексографическом
( в алфавитном) порядке

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
bool Compare( const std::string & str1,const std::string & str2)
{
    if(str1.length() < str2.length())
    return true;
    if(str1.length() > str2.length())
        return false;
 
    if(str1 < str2)
        return true;
    if(str1 > str2)
        return false;
 
    return false;
}

То есть для дерева код будет таким
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int Compare(const std::string &str1, const std::string &str2) {
    if (str1.length() < str2.length())
        return 1;
    if (str1.length() > str2.length())
        return -1;
 
    if (str1 < str2)
        return 1;
    if (str1 > str2)
        return -1;
 
    return 0;
}

Сортировка идет по мере добавления слов в дерево. Сравнивается слово текущего узла и новое слово
Если слово текущего узла меньше то идем влево, вставляем новый узел.
Если больше идем вправо. Когда слова равны , то ничего не делаем.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
struct TreeNode {
    TreeNode *left;
    TreeNode *right;
    std::string data;
};
 
void Insert(TreeNode *&node, const std::string &data) {
 
    if (!node) {
        node = CreateNode(data);
        return;
    }
 
    int c = Compare(node->data, data);
    if (c == 0)  // слова равны
        return;
 
    if (c < 0)
        Insert(node->left, data);
    else
        Insert(node->right, data);
 
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.05.2018, 04:04
Помогаю со студенческими работами здесь

Несбалансированное бинарное дерево с рекурсивным обходом в обратном порядке
добрый день. помогите пожалуйста с реализацией кода: .Несбалансированное бинарное дерево с рекурсивным обходом в обратном порядке (левое...

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

Написать функцию, которая определяет, является ли бинарное дерево симметричным
Написать функцию, которая определяет, является ли бинарное дерево симметричным.

Бинарное дерево поиска
Всем привет! Не могу понять одну вещь. Есть вот такой код для заполнения бинарного дерева: #include &lt;stdio.h&gt; #include...

Бинарное дерево поиска
Я написала программу поиска минимума в массиве или среди элементов массива от i до j. В части запросов программа работает правильно, но...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru