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

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

•  TDictionary Custom Sort  6 514

•  Fast Watermark Sources  6 302

•  3D Designer  9 247

•  Sik Screen Capture  6 637

•  Patch Maker  7 012

•  Айболит (remote control)  7 020

•  ListBox Drag & Drop  5 893

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

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

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

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

•  Canvas Drawing  5 761

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

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

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

•  Paint on Shape  2 816

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

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

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

•  Пазл Numbrix  2 492

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

•  Игра HIP  2 140

•  Игра Go (Го)  2 077

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

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

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

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

•  HEX View  2 599

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

 
скрыть

  Форум  

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

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



Delphi Sources

Вычисление квадратного корня (итерационный аналитический алгоритм)



Автор: Fenik

{ **** UBPFD *********** by delphibase.endimus.com ****
>> Вычисление квадратного корня (итерационный аналитический алгоритм)

Зависимости: нет
Автор:       Fenik, chook_nu@uraltc.ru, Новоуральск
Copyright:   Автор: Федоровских Николай
Дата:        20 апреля 2003 г.
***************************************************** }

function MySqrt(x: Double; n: Byte): Double;
{ x - аргумент
  n - точность вычисления (советую брать 7-8) }
var
  i: Integer;
begin
  if x <= 0 then
  begin
    Result := 0;
    Exit;
  end
  else
    Result := 4;
  for i := 0 to n do
  begin
    Result := (Result + x / Result) / 2;
  end;
end;

Пример использования:

procedure TForm1.FormCreate(Sender: TObject);
var
  n: Double;
begin
  //Тест (сверить с калькулятором)
  n := 29.7665342;
  Caption := 'Sqrt(' + FloatToStrF(n, ffFixed, 10, 5) + ') = ' +
    FloatToStrF(MySqrt(n, 7), ffFixed, 10, 10);
end;




Похожие по теме исходники

Вычисление даты Пасхи

Генетический Алгоритм

Алгоритм Дейкстры

Алгоритм Беллмана-Форда

 



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

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