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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 15.10.2007, 18:17
nike1989 nike1989 вне форума
Прохожий
 
Регистрация: 15.10.2007
Сообщения: 4
Репутация: 10
По умолчанию прога...

итак задали нам по програмированию сделать програмку...
программу я сделал но она помоему считает неверно ...как я подозреваю ошибка в том что она не берет предыдущее значение Аn-1 и Bn-1 подскажите что мне делать
program nike;
const
A0=3;
B0=2;
Eps=10E-6;
var
S:real;
An,Bn:real;
Sn:real;
N:integer;
begin
S:=1;
N:=0;
An:=A0;
Bn:=B0;
repeat
Sn:=Exp(N*ln(2))*(An*An-Bn*Bn)*(-0.5);
s:=sn*(-0.5);
writeln sn;
S:=S+Sn;
An:=0.5*(An+Bn);
Bn:=Sqrt(An*Bn);
Inc (N);
until
(An*An-Bn*Bn)<=Eps;
writeln
('S=',S);
readln;
End.
Изображения
Тип файла: jpg zadanie.JPG (15.9 Кбайт, 13 просмотров)
Ответить с цитированием
  #2  
Старый 15.10.2007, 22:03
Аватар для robonuk
robonuk robonuk вне форума
Прохожий
 
Регистрация: 03.10.2007
Сообщения: 13
Репутация: 10
Злость

Ну для начала зачем каждый цикл умножать на -1/2, когда в условие
сумму надо умножить на 1/2 и то всего один раз??? (Мож я не так понял)
Цитата:
Sn:=Exp(N*ln(2))*(An*An-Bn*Bn)*(-0.5);
Далее Это ЧТо?
Цитата:
s:=sn*(-0.5);
writeln sn;
А тут ты сначало присваеваешь An :=..., а потом от получившегося
An Считаешь Bn...(хотя необходимо было ввести ещё одну переменную:
Z := An;
An:=0.5*(An+Bn);
Bn:=Sqrt(Z*Bn);
А что у тебя
Цитата:
An:=0.5*(An+Bn);
Bn:=Sqrt(An*Bn);

Короче хрен знает мож это я не понимаю ничё
(не судите строго)
Вот переделал:

Код:
program summa_r9da;
uses crt;
const
   e = 0.000001;
var
   S : real;
   A : real;
   B : real;
   Z : real;
   n : integer;
begin
clrscr;
S :=0;
n :=0;
A := 3;
B := 2;
   repeat
         S := S + exp(n*ln(2))*(A*A-B*B);

         Z := A;
         A := (A+B)/2;
         B := sqrt(Z*B);
         inc(n);
   until (A*A-B*B)<=e;

   S := S/2;
   write(' Summa r9da = ',S);

readkey;
end.
Ответить с цитированием
  #3  
Старый 15.10.2007, 22:51
nike1989 nike1989 вне форума
Прохожий
 
Регистрация: 15.10.2007
Сообщения: 4
Репутация: 10
По умолчанию

тупой встречный вопрос...как мне это проверить?? ЗЫ спасибо БОЛЬШОЕ
Ответить с цитированием
  #4  
Старый 15.10.2007, 22:58
Аватар для robonuk
robonuk robonuk вне форума
Прохожий
 
Регистрация: 03.10.2007
Сообщения: 13
Репутация: 10
По умолчанию

Цитата:
Сообщение от nike1989
тупой встречный вопрос...как мне это проверить?? ЗЫ спасибо БОЛЬШОЕ
А вот как проверить фиг его знает=/
когда сдавать будешь там и проверят =)
Ответить с цитированием
  #5  
Старый 15.10.2007, 23:28
nike1989 nike1989 вне форума
Прохожий
 
Регистрация: 15.10.2007
Сообщения: 4
Репутация: 10
По умолчанию

я вывел промежуточные значения С (нупервое это 5 и так ясно (тупо подставив в формулу 3 и 2 соответственно)) дальше 5.5 ...позоде на правду но не уверен а дальше вооще не могу посчитать (всего их три )
Ответить с цитированием
  #6  
Старый 16.10.2007, 18:24
nike1989 nike1989 вне форума
Прохожий
 
Регистрация: 15.10.2007
Сообщения: 4
Репутация: 10
По умолчанию

робонук спасибо те огромное прогу сдал)))есть оазговор можешь связатся сл мной 374411907
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter