IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> рекурсионная функцию формулы х
maksimla
сообщение 27.01.2009 21:35
Сообщение #1


Знаток
****

Группа: Пользователи
Сообщений: 324
Пол: Мужской
Реальное имя: maksim

Репутация: -  1  +


надо написать рекурсионную функцию pow(x, n), находящюю х в n степени по формуле
Прикрепленное изображение

здесь х реальное число а n натуральное число

вот написал чтото
function pow (x,n:real):real;
var m:real; i,p:integer;
begin
p:=abs(trunc(n));
if x=0 then pow(1,p);
if x<0 then
begin
m:=x;
for i:= 1 to p-1 do
x:=x*m;
pow(1/x,p)
end;
if x>0 then
begin
m:=x;
for i:= 1 to p-2 do
x:=x*m;
pow(x*x,p)
end;
end;



а может есть чтобы цыкл неписать какбы написать sqr(x)?
и я правильно написал функцию?


--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 28.01.2009 13:54
Сообщение #2


Гость






Смотри, вот что тут происходит. К примеру, вызываем pow(2, 5).

1. 5 > 0 ==> pow = 2 * pow(2, 4)
2. 4 > 0 ==> pow = 2 * pow(2, 3)
3. 3 > 0 ==> pow = 2 * pow(2, 2)
4. 2 > 0 ==> pow = 2 * pow(2, 1)
5. 1 > 0 ==> pow = 2 * pow(2, 0)
6. 0 = 0 ==> pow = (1)
Теперь раскручиваем все назад: то, что было вычислено на N-ом уровне,
возвращаем на (N-1)-ый (в скобках - результат выполнения, и ниже -
этот же результат используется в вычислении на предыдущем уровне)
pow = 2 * 1 = (2)
pow = 2 * (2) = (4)
pow = 2 * (4) = (8)
pow = 2 * (8) = (16)
pow = 2 * (16) = (32)

Вот тебе и ответ: pow(2, 5) = 32

То же самое делается и при передаче отрицательного числа вторым параметром, только добавляется еще один уровень рекурсии... Попробуй нарисовать такое же дерево для pow(2, -3) самостоятельно...
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 18.07.2025 14:18
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"