Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.61/18: Рейтинг темы: голосов - 18, средняя оценка - 4.61
0 / 0 / 0
Регистрация: 13.07.2017
Сообщений: 32

Вывести k-ое число из последовательности Фибоначчи

29.07.2017, 14:14. Показов 3460. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день моя проблема такова: т. к. так написано в условии задачи (1<=K=>200) а уже 50-ое число силишком большое для longint. Напишите программу которое выведет даже 200 число
вот код:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
var i, ch,ch1,n,ch2:longint;
begin
assign(input, 'input.txt');
reset(input);
assign(output, 'output.txt');
rewrite(output);
read(n);
ch:=0;
ch1:=1;
for i:=1 to n do
begin
ch2:=ch1;
ch1:=ch;
ch:=ch1+ch2
end;
write(ch);
end.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.07.2017, 14:14
Ответы с готовыми решениями:

Вывести n-ое число из последовательности Фибоначчи
На вход задаётся число n, программа должна вывести n-ое число из последовательности Фибоначчи. (1 1 2 3 5 8 13), здесь n- числом (3)...

Дано целое число n > 2 сформировать и вывести целочисленный массив размера n содержащий n первых элементов последовательности чисел фибоначчи
Дано целое число n &gt; 2 сформировать и вывести целочисленный массив размера n содержащий n первых элементов последовательности чисел...

Найти k-ое число последовательности Фибоначчи
Последовательностью Фибоначчи называется последовательность чисел a0, a1, …, an, где a0 = x, a1 = y, ak = ak-1 + ak-2 для k &gt; 1. В...

9
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
29.07.2017, 15:10
Ну это уродство 1<=K=>200 видимо нужно читать как 1<=k<=200.
Если пишете в АВС.net используйте тип biginteger, если другие, то длинная арифметика. Сложение длинных чисел в разделе Паскаль рассматривалось.
Да и другие методы тоже.
Вычислить факториал введенного числа
Найти Факториал числа n
пост номер 3.
0
0 / 0 / 0
Регистрация: 13.07.2017
Сообщений: 32
29.07.2017, 21:32  [ТС]
а если программа пишется в turbo pascal?
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
30.07.2017, 09:57
... почитать темы по ссылкам и написать в Turbo Pascal. Учесть, что Integer там 2-х байтный, до 32767, но Longint 4-х байтный и вместо него подойдет. Сложение в строковом представлении еще проще.
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
30.07.2017, 10:35
Вообще я тебя не в том направлении отправил, попутал Фибоначчи и факториал. Но применять нужно точно длинную арифметику, сложение двух чисел, представленных строками, поскольку длина чисел не превышает 20 знаков.

Добавлено через 17 минут
Пардон, не 20, а 42 знака.

Добавлено через 19 минут
Для примера.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
function summa(s1,s2:string):string;
var s3:string;
    l,{длина большей строки}
    p,{перенос при сложении цифр}
    c,{сумма двух цифр и переноса}
    i:integer;{счетчик}
begin
s3:='';
l:=length(s2);
if length(s1)<length(s2) then
for i:=length(s1) to l-1 do
insert('0',s1,1);
p:=0;
for i:=l downto 1 do
 begin
  c:=ord(s1[i])+ord(s2[i])-96+p;
  p:=c div 10;
  insert(chr(c mod 10+48),s3,1);
 end;
if p>0 then insert('1',s3,1);
summa:=s3;
end;
var   s1,s2,s3: string;
      n,i:integer;
begin
repeat
write('Введите натуральное число от 1 до 200 n=');
readln(n);
until n in [1..200];
if n<3 then write(1)
else
 begin
  s1:='1';
  s2:='1';
  for i:=3 to n do
   begin
    s3:=summa(s1,s2);
    s1:=s2;
    s2:=s3;
   end;
 end;
write(s3);
end.
0
0 / 0 / 0
Регистрация: 13.07.2017
Сообщений: 32
30.07.2017, 17:50  [ТС]
при запуске программы паскаль выдает error: Incomptible types: got "char" expected "longint" и ставит курсор сюда
c:=ord(s1[i])+ord(s2{}[i])-96+p; {}- расположение курсора
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
30.07.2017, 18:03
Не знаю что Вы там напакостили, скопировал я свой код и запустил в Турбо Паскале. Нет никаких ошибок.
Миниатюры
Вывести k-ое число из последовательности Фибоначчи  
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
30.07.2017, 18:09
Цитата Сообщение от Puporev Посмотреть сообщение
c:=ord(s1[i])+ord(s2[i])-96+p;
ord(s1[i])-целое число от 48 до 57
ord(s2[i])-целое число от 48 до 57
96- целое число
p-целое число от 0 до 1
с-целое число от 0 до 19
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
01.08.2017, 07:34
Лучший ответ Сообщение было отмечено Puporev как решение

Решение

Puporev, можно обойтись и без строк.
Так программа получится даже меньше и проще:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
var
  a, b, c : array [0..50] of Byte;
  n, i, p : Byte;
begin
  Read(n); a[0] := 1; a[1] := 1; b[0] := 1; b[1] := 0;
  while n > 1 do
    begin
      for i := 0 to b[0] do c[i] := b[i];
      for i := 0 to a[0] do b[i] := a[i];
      p := 0;
      for i := 1 to b[0] do
        begin
          p := p + b[i] + c[i];
          a[i] := p mod 10;
          p := p div 10;
        end;
      if p > 0 then
        begin
          a[0] := b[0] + 1;
          a[a[0]] := p;
        end
      else
        a[0] := b[0];
      dec(n);
    end;
  for i := a[0] downto 1 do Write(a[i]);
end.
Добавлено через 13 минут
А если хочется на строках, то можно использовать этот же алгоритм ;–)
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
var
  a, b, c : String;
  n, i, p : Integer;
begin
  Read(n);
  a := #1; b := #0;
  while n > 1 do
    begin
      c := b; b := a; a := '';
      while Length(c) < Length(b) do c := c + #0;
      p := 0;
      for i := 1 to Length(b) do
        begin
          p := p + ord(b[i]) + ord(c[i]);
          a := a + chr(p mod 10);
          p := p div 10;
        end;
      if p > 0 then a := a + chr(p);
      Dec(n);
    end;
  for i := Length(a) downto 1 do Write(ord(a[i]));
end.
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
01.08.2017, 07:50
Действительно, и нафига мне понадобились вместо 0..9 48..57? Ввода же нет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.08.2017, 07:50
Помогаю со студенческими работами здесь

Число последовательности Фибоначчи по индексу
Программа должна рассчитывать числа последовательности Фибоначчи. Последовательность Фибоначчи - это последовательность чисел, в которой...

Найти N-ое число последовательности Фибоначчи
Последовательность Фибоначчи Последовательность Фибоначчи выглядит следующим образом: 1, 1, 2, 3, 5, 8, 13, 21, …. В этой...

Вычислить n-е число последовательности Фибоначчи рекурсивно
Напишите программу на языке программирования С#, вычисляющее n-е число последовательности Фибоначчи рекурсивно. Посчитайте количество...

Найти первое число в последовательности Фибоначчи, большее n
несколько задач.помогите студенту 1. Последовательность Фибоначчи образуется так: первый и второй члены последовательности равны 1,...

Найти первое число в последовательности Фибоначчи, большее n
Найти: 1. Первое число в последовательности Фибоначчи, большее n(значение n вводится с клавиатуры; n&gt;1) 2. сумму всех чисел в этой...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru