Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на языке Pascal


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Лучшие эксперты данной рассылки

lamed
Статус: Академик
Рейтинг: 5213
∙ повысить рейтинг »
Орловский Дмитрий
Статус: Академик
Рейтинг: 5180
∙ повысить рейтинг »
Boriss
Статус: Академик
Рейтинг: 2670
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И СОФТ / Программирование / Pascal (Паскаль)

Номер выпуска:1182
Дата выхода:29.05.2011, 21:00
Администратор рассылки:Boriss (Академик)
Подписчиков / экспертов:175 / 174
Вопросов / ответов:1 / 1

Вопрос № 183323: Здравствуйте! Прошу помощи в следующем вопросе: вариант 4:


Вопрос № 183323:

Здравствуйте! Прошу помощи в следующем вопросе:
вариант 4:


Отправлен: 24.05.2011, 20:34
Вопрос задал: Русинов Алексей Игоревич (1-й класс)
Всего ответов: 1
Страница вопроса »


Отвечает Сергей Бендер (Практикант) :
Здравствуйте, Русинов Алексей Игоревич!

Извините, сразу не написал. Вот тут есть аналогичное задание.
165744
Я добавил метод прямоугольников.

Код :
program p183323;

const
  a = 0;{нижний предел}
  b = 1.5708;{верхний предел}
  n = 10;{разбиение}

function f(x: real): real;
begin
  f := x * sin(x);
end;

function IntegralPriam(a, b: real): real;
{метод прямоугольников}
var
  h, k, s: real;
  i: Integer;
begin
  h := (b - a)/N;
  s := 0;
  k := a + h/2;
  for i := 0 to N - 1 do
    begin
      s := s + f(k);
      k := k + h;
    end;
  s := s*h;

  IntegralRect := s;
end;

function IntegralTrap(a, b: real): real;
{метод трапеций}
var
  h, k, s: real;
  i: Integer;
begin
  h := (b - a)/N;
  s := (f(a) + f(b))/2;
  k := a;
  for i := 1 to N - 1 do
    begin
      k := k + h;
      s := s + f(k);
    end;
  s := s*h;

  IntegralTrap := s;
end;

function IntegralSimpson(a, b: real): real;
{метод симпсона}
var
  h, k, s: real;
  i: Integer;
begin
  h := (b - a)/N;
  s := 0;
  k := a;
  for i := 1 to N - 1 do
    begin
      k := k + h;
      if i mod 2 = 0 then
        s := s + 2*f(k)
      else
        s := s + 4*f(k);
    end;

  s := (s + f(a) + f(b))*h/3;

  IntegralSimpson := s;
end;

begin
  writeln('Metodom Piamougolnikov = ', IntegralPriam(a, b):0:5);
  writeln('Metodom Trapecij = ', IntegralTrap(a, b):0:5);
  writeln('Metodom Simpsona = ', IntegralSimpson(a, b):0:5);
  readln
end.

Ответ отправил: Сергей Бендер (Практикант)
Ответ отправлен: 26.05.2011, 21:43
Номер ответа: 267402
Тел.: 8-912-761-0437
Организация: Удмуртский ГосУнивеситет. г. Ижевск.
Абонент Skype: ostapbskype

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 267402 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:


  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.



    В избранное