Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Рекурсивный алгоритм?

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Nick T
Гость





СообщениеДобавлено: Вт Сен 21 2004 08:53    Заголовок сообщения: Рекурсивный алгоритм? Ответить с цитатой

Привет, всем, наверняка кто-то встречался недавно с похожей задачей, поэтому может подскажите в праильном направлении я двигаюсь или нет?

Итак, общо задача формулируется как интегрирование по N мерному объекту, где N заранее не известно. Мне кажется что именно в таких случаях правильно использовать рекурсию, НО последний раз я это делал лет 8 назад, поэтому это единственное что я еще помню, нет ли ссылок на какие либо исходники с реализацией? Еще мне кажется что именно рекурсией строятся все фракталы, но может быть у меня в голове что-то смешалось. Кроме исходников любые советы тоже приму с удовольствием к сведению. Заранее спасибо!
Вернуться к началу
droopy



Зарегистрирован: 28.07.2004
Сообщения: 168

СообщениеДобавлено: Вт Сен 21 2004 08:57    Заголовок сообщения: Ответить с цитатой

Сформулируй четко задачу. Н мерный объект, это функция Н переменных? Насколько я помню интегрировать можно только функции.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail Посетить сайт автора
Гость






СообщениеДобавлено: Вт Сен 21 2004 13:55    Заголовок сообщения: Ответить с цитатой

ну да, все верно...
Вернуться к началу
droopy



Зарегистрирован: 28.07.2004
Сообщения: 168

СообщениеДобавлено: Вт Сен 21 2004 20:19    Заголовок сообщения: Ответить с цитатой

Поставь конкретно задачу. А то у тебя иди туда не знаю куда
принеси то не знаю что. А вообще в поиск по численным методам.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail Посетить сайт автора
GREA



Зарегистрирован: 14.05.2003
Сообщения: 758
Откуда: Новосибирск

СообщениеДобавлено: Вт Сен 21 2004 21:35    Заголовок сообщения: Ответить с цитатой

Правильнее будет: интегрирование функций N-переменных, на компактном непрерывном N-мерном множестве точек(объекте).
Кстати, интегрирование может производится как по мере объема, так и поверхностной мере (что именно тебе нужно?).
Кроме того, интегрируемая функция может иметь в области определения точки неустранимого разрыва.
Вообще, можно почитать численные методы Волкова или Самарского. Общий алгоритм: Аппроксимируешь объект разбиением на некие примитивы(кубы, параболы...) мелкого размера, интеграл от которых легко посчитать аналитически. Никакой рекурсии не надо. N вложенных циклов(по каждой переменной). То есть пробегаешь все симплексы (элементарные примитивы) по N-мерному граничному кубу, проверяешь данный симплекс на вхождение в объект и интегрируешь его.
А чтобы аналитически посчитать, тут уж нужна рекурсия и синтаксический анализатор. Но обычно на практике так делают редко.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
GREA



Зарегистрирован: 14.05.2003
Сообщения: 758
Откуда: Новосибирск

СообщениеДобавлено: Вт Сен 21 2004 21:46    Заголовок сообщения: Ответить с цитатой

У тебя верно возникнет вопрос, как реализовать N-циклов.
Через рекурсию - изврат. Интеграл будет считаться вечность. Используй стек, для реализации циклов. В стеке N-записей. Каждая запись - суть счетчик i-го цикла.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
GREA



Зарегистрирован: 14.05.2003
Сообщения: 758
Откуда: Новосибирск

СообщениеДобавлено: Вт Сен 21 2004 21:52    Заголовок сообщения: Ответить с цитатой

В догонку: раз речь зашла о фракталах. Рекурсия применяется только в тех из них, которые базируются на аффинных преобразованиях. Например, треугольник и ковер Серпинского, кривая Коха, драконова линия.
В множествах Жулиа (Джулии) и Мандельброта рекурсия по сути отсутвует (цвет точки определяет число итераций, что ближе к циклам).
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Гость






СообщениеДобавлено: Ср Сен 22 2004 14:43    Заголовок сообщения: Ответить с цитатой

Grea
Огромное спасибо, да вопрос был именно про реализацию N циклов! Сейчас думаю как реализовать стек, пока не придумал, но наверное смогу что-нибудь придумать.

Про фракталы, как приятно слышать знакомые названия, только Коха это все-таки снежинка Smile) А вот что такое драконова линия не подскажешь для общего образования?
Вернуться к началу
GREA



Зарегистрирован: 14.05.2003
Сообщения: 758
Откуда: Новосибирск

СообщениеДобавлено: Ср Сен 22 2004 15:43    Заголовок сообщения: Ответить с цитатой

Кривая Коха, это ломаная, полученная на базе _/\_
А стек - это обычный массив, где элементов взято с запасом.
Единственные операции над ним - взять из вершины стека, и положить в вершину стека. Естественно, нужна еще переменная, показывающая число эл-тов в стеке.
И вогнать это дело в цикл и систему if, которые будут организовывать перебор по переменным.

Подробнее о фракталах на
http://home.ural.ru/~shabun/fractals/fractals.htm#gfra

А вот это вообще обалденно:
http://www.arbuz.uz/t_chaoscope.html
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Sharkky



Зарегистрирован: 10.01.2004
Сообщения: 72

СообщениеДобавлено: Ср Сен 22 2004 19:11    Заголовок сообщения: Ответить с цитатой

Стэк - посмотри STL. Делать самому такие вещи неправильно.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...