Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на Delphi и Lazarus


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Boriss
Статус: Академик
Рейтинг: 1689
∙ повысить рейтинг »
lamed
Статус: Практикант
Рейтинг: 1252
∙ повысить рейтинг »
Jimhucksly
Статус: 5-й класс
Рейтинг: 659
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Delphi и Lazarus

Номер выпуска:1482
Дата выхода:20.01.2010, 22:30
Администратор рассылки:Калашников О.А., Руководитель
Подписчиков / экспертов:585 / 225
Вопросов / ответов:1 / 1

Вопрос № 176070: Уважаемые эксперты. Нужна помощь с бинарным деревом. Нужно написать процедуру которая меняет местами максмальный и минимальный элемент дерева, и которая выводит в Edit все листы дерева. Добавление и просмотр уже есть в архиве. Пожалуйста помогите, ес...



Вопрос № 176070:

Уважаемые эксперты. Нужна помощь с бинарным деревом. Нужно написать процедуру которая меняет местами максмальный и минимальный элемент дерева, и которая выводит в Edit все листы дерева. Добавление и просмотр уже есть в архиве. Пожалуйста помогите, если можете. Заранее спасибо.
Tree >>

Отправлен: 15.01.2010, 22:22
Вопрос задал: Камынин Владислав Дмитриевич, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает Сергей Бендер, 4-й класс :
Здравствуйте, Камынин Владислав Дмитриевич.

Итак.
По первому пункту. Тут задача немного нескладная. С одной стороны у тебя в
заготовке дерево строится упорядоченным. С другой стороны, если мы меняем
местами макс. и мин. элементы, то оно заведомо перестаёт быть таковым. Я
прикинул и решил всё-таки воспользоваться упорядоченностью дерева -- проще
алгоритм. Т.е. циклом while идём по левым веткам до nil'а -- получаем
минимум, идём по правым веткам -- получаем максимум. Но! В этом случае
команда получается "одноразовой". Т.е. если после престановки ещё добавить
элементов, то новая перестановка минимума и максимума будет некорректной.

Если надо, можно переписать, сделать перестановку более общей.


По второму пункту. Это можно сделать очень просто. То же самое что и
просто вывод, только с дополнительным условием
(t1.ls=nil) and (t1.rs=nil)


Код в приложении. (Комментариев не писал -- думаю , я тут уже всё
объяснил.)

Проверка второго пункта.
Вводим по очереди:
0 -3 5 -4 -2 -1 3 2

Получается дерево:
http://rfpro.ru/upload/1378

Вывод листьев:
-4,-1,2,4

Приложение:

Ответ отправил: Сергей Бендер, 4-й класс
Ответ отправлен: 18.01.2010, 18:26

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 258719 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2009.6.13 от 28.12.2009

    В избранное