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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 02.04.2009, 14:36
Pitt Pitt вне форума
Прохожий
 
Регистрация: 02.04.2009
Сообщения: 2
Репутация: 10
По умолчанию Числа Фибоначчи

как найти количество сложений для вычисления N-ого числа Фибоначчи?
а вернее,как реализовать?
Ответить с цитированием
  #2  
Старый 02.04.2009, 14:48
Аватар для PhoeniX
PhoeniX PhoeniX вне форума
Always hardcore!
 
Регистрация: 04.03.2009
Адрес: СПб
Сообщения: 3,239
Версия Delphi: GCC/FPC/FASM
Репутация: 62149
По умолчанию

Мда... это которая "1 1 2 3 5 8 13"...?
В голову ничего не приходит, кроме как прокрутить последовательность в цикле, и в цикле это дело оформить... Голова болит , так что может, кто лучше идею даст...
__________________
Оставайтесь хорошими людьми...
VK id2634397, ds [at] phoenix [dot] dj

Последний раз редактировалось PhoeniX, 03.04.2009 в 22:02.
Ответить с цитированием
  #3  
Старый 02.04.2009, 15:02
Аватар для Thrasher
Thrasher Thrasher вне форума
Illuminati
 
Регистрация: 06.03.2008
Адрес: Крым, г. Симферополь
Сообщения: 348
Репутация: 8808
По умолчанию

Тут есть как находить Фибоначчи числа и заодно как находить количество сложений
__________________
Хорошо написанная программа не требует документации
ICQ 9-184-668.
Ответить с цитированием
  #4  
Старый 02.04.2009, 15:10
Аватар для rasamaha
rasamaha rasamaha вне форума
Прохожий
 
Регистрация: 28.03.2009
Сообщения: 19
Репутация: 10
По умолчанию

может тебе нужен порядковый номер конкретного числа в ряду Фибоначчи?
для начала могу подсказать алгоритм))
(я это когда то на плюсах делал, позже попробую код вспомнить)

1) сначала надо определить числа, входящие в ряд, желательно список ограничить наибольшим.
2) а потом уже можно узнать входит ли число в ряд Фи
3) затем:
количество сложений = (порядковому номеру в строке или массиве -1);

может это и через ж..пу, я еще начинающий....
Ответить с цитированием
  #5  
Старый 08.04.2009, 00:55
Pitt Pitt вне форума
Прохожий
 
Регистрация: 02.04.2009
Сообщения: 2
Репутация: 10
По умолчанию

через цикл примерно знаю,а как можно применить рекурсию?)
знаю что так сложнее,но преподу пофиг,хотя сам не представляет
Ответить с цитированием
  #6  
Старый 09.04.2009, 21:33
Otmorozok Otmorozok вне форума
Прохожий
 
Регистрация: 09.04.2009
Сообщения: 1
Репутация: 10
По умолчанию

Код:
function pr(n,n1,n2:integer):integer;
begin
if n>2 then
result:=pr(n-1,n2,n1+n2)
else
result:=n1+n2;
end;

lmikle: Хде теги?!!

Пример использования для N>2:

r:=pr(5,1,1);//Для 5-ого члена последовательности. Дольше думай сам.

Последний раз редактировалось Otmorozok, 09.04.2009 в 21:40.
Ответить с цитированием
  #7  
Старый 10.04.2009, 01:33
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,088
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Вообще-то, рекурсивную функцию расчета чисел фибоначи можно посмотреть в любом учебнике. Она очень простая.

Код:
// Возвращает Nый элемент ряда фибоначи
function Fib(N : Integer) : Integer;
begin
  If N < 3 
    Then Result := 1
    Else Result := Fib(N-1) + Fib(N-2);
end;

В принципе, сюда можно имплантировать счетчик для подсчета числа сложений. Сделать доп. var-параметр и увеличивать его на 1 в ветке Else.
Ответить с цитированием
  #8  
Старый 04.08.2010, 11:22
Аватар для ***
*** *** вне форума
Прохожий
 
Регистрация: 20.06.2010
Сообщения: 47
Репутация: 0
По умолчанию

Цитата:
Сообщение от Pitt
как найти количество сложений для вычисления N-ого числа Фибоначчи?
а вернее,как реализовать?

Посмотри тут => http://delphi-lubitel.ucoz.ru
Ответить с цитированием
  #9  
Старый 04.08.2010, 12:56
Аватар для Konrad
Konrad Konrad вне форума
Эксперт
 
Регистрация: 19.03.2009
Сообщения: 1,261
Репутация: 45834
По умолчанию

Цитата:
Сообщение от ***
Посмотри тут => http://******.ucoz.ru
И где смотреть? На переполненном рекламными баннерами сайте неизвесно о чем?)
Ответить с цитированием
  #10  
Старый 18.10.2010, 17:11
Аватар для ***
*** *** вне форума
Прохожий
 
Регистрация: 20.06.2010
Сообщения: 47
Репутация: 0
Лампочка Ответ

Цитата:
Сообщение от Konrad
И где смотреть? На переполненном рекламными баннерами сайте неизвесно о чем?)
А не судьба заглянуть в исходники или в видео уроки ????? Специально для тебя вот ссылочка http://delphi-lubitel.ucoz.ru/index/...bonachchi/0-31 чтобы посмотреть нужно авторизоваться. Скачать можно тут http://depositfiles.com/ru/files/upai4innx Еще чтонить предьявишь ?
Ответить с цитированием
  #11  
Старый 18.10.2010, 17:38
Аватар для Konrad
Konrad Konrad вне форума
Эксперт
 
Регистрация: 19.03.2009
Сообщения: 1,261
Репутация: 45834
По умолчанию

С твоего рекламо-сайта:
Код:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    Label1: TLabel;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}
function fib(n:integer):integer;
begin
if n<2 then fib:=1 else fib:=fib(n-1)+fib(n-2);
end;

procedure TForm1.Button1Click(Sender: TObject);
var i:integer;
begin
for i := 1 to 20 do
label1.Caption := label1.Caption + Inttostr(fib(i))+', ';

end;

end.

И чем это лучше ответа?:
Цитата:
Сообщение от lmikle
Вообще-то, рекурсивную функцию расчета чисел фибоначи можно посмотреть в любом учебнике. Она очень простая.

Код:
// Возвращает Nый элемент ряда фибоначи
function Fib(N : Integer) : Integer;
begin
  If N < 3 
    Then Result := 1
    Else Result := Fib(N-1) + Fib(N-2);
end;

Иными словами, ответ уже ранее подсказали http://www.delphisources.ru/forum/sh...85&postcount=7,
но ты все равно продолжаешь впихивать свой сайт...

Последний раз редактировалось Konrad, 18.10.2010 в 17:41.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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