Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 02.07.2010, 14:16
csoft csoft вне форума
Прохожий
 
Регистрация: 02.07.2010
Сообщения: 3
Репутация: 9
Восклицание Программа на рекурсию. Помогите дописать прогу!

Здравствуйте! У меня возникла небольшая проблема: не могу дописать программу по рекурсии.
Вот условие задачи:
-------------------------
Задано натуральное N. Разработать программу для подсчета заданной сумы (использовать рекурсивные процедуры или функции):

------------------------

Намучился с этой прогой.. Сделал только функцию для подсчета (k+1)! в Ak, и то не знаю правильно ли:
Код:
Function zn(k:integer):double;
begin
if k=0 then result:=1
else
result:=zn(k)*(k+1);
end;

Пожалуйста, помогите написать программу! Скоро надо сдавать лабу..
Ответить с цитированием
  #2  
Старый 02.07.2010, 15:44
Аватар для Rokuell
Rokuell Rokuell вне форума
Активный
 
Регистрация: 27.12.2006
Адрес: Псков
Сообщения: 274
Версия Delphi: Delphi 7
Репутация: 497
Сообщение

Код:
program Project1;

{$APPTYPE CONSOLE}

function Recursiv(k,n,f:int64):Double;
begin
 if k=n then
  begin
   Result := ( 1 - 1/f/(k+1) );
  end
 else
  begin
   Result := ( 1 - 1/f/(k+1) ) + Recursiv(k+1,n,-f*(k+1));
  end;
end;

begin
 Writeln( Recursiv(1,10,1):0:8 );
 Readln;
end.

Recursiv(k,n,f) - k и f - всегда передавай 1, n - заданное натуральное N
__________________
Велик и могуч наш Object Pascal !
ICQ: 357-591-887

Последний раз редактировалось Rokuell, 02.07.2010 в 15:46.
Ответить с цитированием
  #3  
Старый 02.07.2010, 16:50
csoft csoft вне форума
Прохожий
 
Регистрация: 02.07.2010
Сообщения: 3
Репутация: 9
По умолчанию

Цитата:
Сообщение от Rokuell
Код:
program Project1;

{$APPTYPE CONSOLE}

function Recursiv(k,n,f:int64):Double;
begin
 if k=n then
  begin
   Result := ( 1 - 1/f/(k+1) );
  end
 else
  begin
   Result := ( 1 - 1/f/(k+1) ) + Recursiv(k+1,n,-f*(k+1));
  end;
end;

begin
 Writeln( Recursiv(1,10,1):0:8 );
 Readln;
end.

Recursiv(k,n,f) - k и f - всегда передавай 1, n - заданное натуральное N

Здравствуйте, Rokuell. Большое спасибо за помощь.
Не могу понять: вы запрограммировали все выражение рекурсии или какую-то часть? Объясните, пожалуйста.
Ответить с цитированием
  #4  
Старый 02.07.2010, 17:02
csoft csoft вне форума
Прохожий
 
Регистрация: 02.07.2010
Сообщения: 3
Репутация: 9
По умолчанию

И еще: выдает ошибку:

[Error] Unit3.pas(88): Incompatible types: 'Int64' and 'Real'

Как я понял несовместимы типы.
Ругается га строчку:

s:=Recursiv(1,n,1);

Для переменных S, N задал такие типы:

n:real;
s:int64;
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 09:58.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025