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

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

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

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

Метод половинного деления в Delphi

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

mary yu

Новые
Регистрация
6 Янв 2010
Сообщения
14
Реакции
0
Баллы
0
Метод половинного деления в Delphi

Теплого времени суток!Помогите разобраться в ошибке.Нужно решить линейное уравнение методом половинного деления
x*x*x*x+4.61*x*x*x-6.45*x*x-29.24*x+24.05=0
Код:
unit Unit1;

interface

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

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

var
  Form1: TForm1;

implementation
function f(x:real):real;
begin
f:=x*x*x*x+4.61*x*x*x-6.45*x*x-29.24*x+24.05
end;
function f1(x:real):real;
begin
f1:=4*x*x*x+13.83*x*x-12.9*x-29.24
end;
function f2(x:real):real;
begin
f2:=12*x*x+27.66*x-12.9
end;
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject);
var x,x1,x0,a,b,e:real;
k:integer;
begin
e:=0.1;
a:=1;
b:=2;x:=2;
if f(b)*f2(x)>0 then
begin
k:=0;x1:=b;
repeat
x0:=x1;
k:=k+1;
x1:=x0-(f(x0)/f1(x0));
form1.Label1.Caption:=form1.Label1.Caption+intToStr(k)+' '+floattostr(x1)+''+formatfloat('#0.##########',abs(x0-x1))+#13;
while abs(x0-x1)<e
end;
else
begin
k:=0;
x1:=a;
repeat
x0:=x1;
k:=k+1;
x1:=x0-(f(x0)/f1(x0));
form1.Label1.Caption:=form1.Label1.Caption+inttostr(k)+' '+floattostr(x1)+' '+formatfloat('#0.######,'abs(x0-x1))+#13;
while abs(x0-x1)<e
end;
form1.Label3.Caption:=form1.Label3.Caption+'k'+' '+' '+' '+' |x0-x1|';
form1.Label2.Caption:=form1.Label2.Caption+'значение функции.---'+formatfloat('#0.##########',f(x1));
end;
procedure TForm1.Button2Click(Sender: TObject);
begin
close;
end;
end.
Выводит ошибку здесь
while abs(x0-x1)<e
end;
else
begin
k:=0;
x1:=a;

Убираю ; все равно недоволен=( Исправьте плиз!
 
Цикл repeat заканчивается не словом while, а словом until :) в остальные особенности не вникал
 
Последнее редактирование:
И еще: перед else символ точка с запятой не ставится
 
Урра!все получилось!исправила ошибки!спасибо!
 
Будьте внимательнее :) и смотрите текст ошибок, которые выдает компилятор
 
Назад
Сверху