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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 23.12.2009, 18:49
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию Рекурсивная процедура

Почему рекурсия работает не правильно??
она должна сосчитать выражение 1 + 2*2 + 4*4 +7*7 +11*11 .....

Код:
procedure summa1(n:real;var s:real);
begin
if n=1 then s:=1
else
   begin  summa1(n-1,s);
    s:=s+ (1 + n * (n - 1) / 2)*(1 + n * (n - 1) / 2);
         end;
end;
Ответить с цитированием
  #2  
Старый 23.12.2009, 18:58
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,087
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

1. n лучше задать как Integer
2. А в чем неправильно-то?
Ответить с цитированием
  #3  
Старый 23.12.2009, 19:03
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию

Считает неправильно
Ответить с цитированием
  #4  
Старый 23.12.2009, 20:06
Аватар для Ferra
Ferra Ferra вне форума
Местный
 
Регистрация: 12.03.2006
Адрес: Минск
Сообщения: 527
Репутация: 1336
По умолчанию

повелитель реккурентных соотношений блин)
правильное:
1 + [ n(n-1)/2 ] * [ 2 + n(n-1)/2]

Я чуток видоизменил код, так думаю понятнее
Код:
function Func(N : Word) : Int64;
begin
 Result := 1 + (N*(N - 1) div 2) * (2 + N*(N - 1) div 2) ;
end;

function CalculateSum(const N : Word) : Int64;
begin
 if N >= 1 then Result := Func(N) + CalculateSum(N - 1)
  else Result := 0;
end;

Вот пример вызова:
Код:
...
ShowMessage(IntToStr(CalculateSum(3)));
...

удачи)
__________________
Нет повести печальнее на свете, чем повесть о заклиневшем Resete.
Ответить с цитированием
  #5  
Старый 23.12.2009, 20:44
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию

1 + [ n(n-1)/2 ] * [ 2 + n(n-1)/2] не могу понять почему так???????????
Ответить с цитированием
  #6  
Старый 23.12.2009, 20:51
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию

Мне нужна процедура......
Ответить с цитированием
  #7  
Старый 23.12.2009, 22:06
Аватар для Konrad
Konrad Konrad вне форума
Эксперт
 
Регистрация: 19.03.2009
Сообщения: 1,261
Репутация: 45834
По умолчанию

Цитата:
Сообщение от Asira
Мне нужна процедура......

И тут этот Asira... Уже 6-я тема за последние 3 дня.

Такое впечатление что делаешь проги за деньги, вот только навыков отладки нехватает.Зарабатываем перед сессией?

Последний раз редактировалось Konrad, 23.12.2009 в 22:10.
Ответить с цитированием
  #8  
Старый 23.12.2009, 22:27
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию

Если бы так............ я всё себе делаю.... просто в течение семестра ерундой страдал а сейчас решил заняться......... у меня вообще нету никаких навыков я ток 1 год учусь........ вот пытаюсь тут чему то научиться

Последний раз редактировалось Asira, 27.12.2009 в 18:16.
Ответить с цитированием
  #9  
Старый 23.12.2009, 22:35
Аватар для Konrad
Konrad Konrad вне форума
Эксперт
 
Регистрация: 19.03.2009
Сообщения: 1,261
Репутация: 45834
По умолчанию

Цитата:
Сообщение от Asira
Если бы так............ я всё себе делаю.... просто в течение семестра ерундой страдала а сейчас решила заняться......... у меня вообще нету никаких навыков я ток 1 год учусь........ вот пытаюсь тут чему то научиться
Тогда вынужден тебя огорчить, если будешь продолжать строчить темы на форуме - никогда не научишся. Учись находить ответы без помощи.
Ответить с цитированием
  #10  
Старый 23.12.2009, 22:43
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию

Нет уж я хочу, могу и буду учиться на своих ошибках..... А свои ошибки порой бывает трудно найти, поэтому я обращаюсь за помощью на этот форум........... а зачем тогда вообще нужен будет ЭТОТ форум если все будут сидеть и додумываться сами???????????????
Толку бы не было если б я писал темы " Напишите за меня программу" ..........
Вообщем меня не сможет понять человек который не был на моём месте......

Последний раз редактировалось Asira, 27.12.2009 в 18:17.
Ответить с цитированием
  #11  
Старый 23.12.2009, 22:50
Аватар для Rokuell
Rokuell Rokuell вне форума
Активный
 
Регистрация: 27.12.2006
Адрес: Псков
Сообщения: 274
Версия Delphi: Delphi 7
Репутация: 497
По умолчанию

У тебя задание посчитать именно рекурсией или надо просто сосчитать ?

Например можно просто считать n-ые члены этой последовательности (1,4,16,49,121...) и складывать их.

Код:
function Sum(n:integer):integer;
var i:integer;
begin
 Result := 1;
 for i:=2 to n do
  Result := Result + Sqr(1+( i*(i-1) div 2));
end;

вот ссылка на саму последовательность:
http://www.research.att.com/~njas/sequences/A086601
__________________
Велик и могуч наш Object Pascal !
ICQ: 357-591-887
Ответить с цитированием
  #12  
Старый 23.12.2009, 22:54
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию

обычную я сделал а с рекурсией тормоз....

Последний раз редактировалось Asira, 27.12.2009 в 18:17.
Ответить с цитированием
  #13  
Старый 23.12.2009, 23:02
Аватар для Rokuell
Rokuell Rokuell вне форума
Активный
 
Регистрация: 27.12.2006
Адрес: Псков
Сообщения: 274
Версия Delphi: Delphi 7
Репутация: 497
По умолчанию

Код:
procedure summa1(n:integer; var s:integer);
begin
 if n = 1 then s := 1
 else 
  begin
   summa1(n-1,s);
   s := s + Sqr(1+( n*(n-1) div 2));
  end;
end;
__________________
Велик и могуч наш Object Pascal !
ICQ: 357-591-887
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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