• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Упражнение из учебника по Паскалю

  • Автор темы Автор темы Linka
  • Дата начала Дата начала

Linka

Новые
Регистрация
24 Янв 2010
Сообщения
43
Реакции
1
Баллы
0
Упражнение из учебника по Паскалю

Вот такое задание из учебника. Никак не могу понять. По теме "рекуррентная последовательность".

Ссылка удалена

1. Что такое "предельное значение ряда" ?
2. y0 задается произвольно, но желательно ближе к корень из x. "Желательно", это значит, все-таки я могу абсолютно произвольную величину выбрать ?

Вот как я себе это представляю все: каждый новый элемент ряда, добавляет точности к функции. Т.е. на один знак точнее и точнее. Или неверно ?

Помогите пожалуйста это реализовать. Каждый след. член надо вычислять из предыдущего. Здесь требуется рекурсия функции ? Или можно просто с помощью цикла с условием эпсилона?
Самая главная проблема, это - как задать предыдущий член ? К примеру там надо прибавлять yk-1. А как указать на этот предыдущий член ?

Спасибо заранее всем больше за ответы.
 
Последнее редактирование модератором:
Вот, что у меня получилось:
Код:
program rekurrent6;

var a,a0:real;
x:integer;
begin
x:=3;
a0:=1.7;
a:=0.5*(a0+(x/a0));

repeat
a:=0.5*(a+(x/a));
until abs(a) > 1e-7;

writeln(a);
readln;
end.

На примере y=корень из 3. Число, похоже правильное выводится. Если взять 5, тоже уже видно различие с моим числом, и тем что на калькуляторе. Не понятно, с эпсилоном. Как его правильно задать ? Как написано в условии ? Спасибо)
 
Ну что же, в принципе - всё правильно. Но есть несколько замечаний.
1. В условии выхода из цикла Repeat-Until знак отношения перепутан. Надо не ">", а "<". А сейчас у Вас цикл выполняется ровно один раз, потому что получившийся в первый раз результат заведомо больше крохотного числа, стоящего справа.
2. Условие остановки вычисления нужно задавать, как просят в условии задачи, т.е. по разности предыдущей и последующей итераций, если же пытаться по абсолютному значению результата итерации, то оно не стремится к 0, и поэтому цикл будет продолжаться вечно. Поставить правильно условие совсем просто.
3. Это скорее косметика. Программу лучше зациклить и вводить х с консоли. Условием прерывания можно поставить, например, х=0.
4. Опять же косметика. Для сравнения можно вывести точное значение корня. Чтобы не возиться с калькулятором.
5. И еще немного косметики. Вывод лучше сделать форматным - так красивее.
Итого:

Код:
program rekurrent6;

var
 a,a0,b:real;
 x:integer;

begin
 repeat
  Write('Integer x (x=0 terminates the program)= ');
  ReadLn(x);
  If x>0 then
   begin
    a0:=x;
    a:=0.5*(a0+(x/a0));
    repeat
     b:=a;
     a:=0.5*(a+(x/a));
    until abs(a-b)<1e-7;
    writeln(a:14:10,'    ',SQRT(x):14:10);
   end;
 until x=0;
end.
 
Спасибо! Теперь все понятно.
 
Назад
Сверху