Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 303

•  TDictionary Custom Sort  6 348

•  Fast Watermark Sources  6 138

•  3D Designer  9 075

•  Sik Screen Capture  6 460

•  Patch Maker  6 877

•  Айболит (remote control)  6 859

•  ListBox Drag & Drop  5 734

•  Доска для игры Реверси  96 625

•  Графические эффекты  7 079

•  Рисование по маске  6 380

•  Перетаскивание изображений  5 251

•  Canvas Drawing  5 622

•  Рисование Луны  5 323

•  Поворот изображения  4 871

•  Рисование стержней  3 456

•  Paint on Shape  2 714

•  Генератор кроссвордов  3 591

•  Головоломка Paletto  2 884

•  Теорема Монжа об окружностях  3 690

•  Пазл Numbrix  2 424

•  Заборы и коммивояжеры  3 106

•  Игра HIP  2 067

•  Игра Go (Го)  1 992

•  Симулятор лифта  2 351

•  Программа укладки плитки  2 053

•  Генератор лабиринта  2 512

•  Проверка числового ввода  2 199

•  HEX View  2 526

•  Физический маятник  2 141

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Квадратное уравнение



unit SqRoot_;

interface

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

type
  TForm1 = class(TForm)
    Edit1: TEdit;
    Edit2: TEdit;
    Edit3: TEdit;
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Button1: TButton;
    Label5: TLabel;
    Button2: TButton;
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

// решает квадратное уравнение

procedure SqRoot(a, b, c: real; var x1, x2: real; var ok: boolean);
    { a,b,c - коэффициенты уравнения
      x1,x2 - корни уравнения
      ok = True  - решение есть
      ok = False - решения нет }
var
  d: real; // дискриминант
begin
  d := Sqr(b) - 4 * a * c;
  if d < 0
    then
    ok := False // уравнение не имеет решения
  else
  begin
    ok := True;
    x1 := (-b + Sqrt(d)) / (2 * a);
    x2 := (b + Sqrt(d)) / (2 * a);
  end;
end;
{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var
  k1, k2: real; // корни уравнения
  rez: boolean; // True - решение есть, False - решения нет
  mes: string; // сообщение
begin
  SqRoot(StrToFloat(Edit1.Text), StrToFloat(Edit2.Text),
    StrToFloat(Edit3.Text), k1, k2, rez);
  if rez then
    mes := 'Корни уравнения' + #13 +
      'x1=' + FloatToStrF(k1, ffGeneral, 4, 2) + #13 +
      'x2=' + FloatToStrF(k2, ffGeneral, 4, 2) + #13
  else
    mes := 'Уравнение не имеет решения';

  label5.Caption := mes;
end;

procedure TForm1.Button2Click(Sender: TObject);
begin
  winhelp(Form1.Handle, 'sqroot.hlp', HELP_CONTEXT, 1);
end;

end.







Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте