Понедельник, 29 Апр 2024, 01:13
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Высшая математика [11]
Экономическая социология [95]
Основы Менеджмента [64]
Бухгалтерский учёт [157]
Философия [163]
Мировая Экономика [603]
Бизнес планирование [29]
Финансирование и кредитование инвест [105]
Ценообразование [46]
Гражданское право [196]
Права Человека [173]
Основы Маркетинга [207]
Основы энергосбережения [55]
Информатика [0]
Экология и устойчивое развитие [0]
Физика для студентов [0]
Основы права [0]
Политология [0]
Не стандартные примеры на Delphi [169]
Примеры на Delphi7 [108]
Алгоритмы [94]
API [110]
Pascal [152]
Базы Данных [6]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51635


Онлайн всего: 2
Гостей: 2
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

Каталог статей


Главная » Статьи » Студентам » Алгоритмы

Преобразование дробной и целой части REAL-числа в два целых
Преобразование дробной и целой части REAL-числа в два
целых

Я написал программу, которая делает это. Это DOS-программа. Вы вызываете
ее с десятичным числом, передаваемым в качестве параметра. После чего программка
выведет 3 колонки, в первой будет находиться исходное число, две остальные будут
содержать числитель и знаменатель. Вы можете преобразовать программу в функцию и
применять ее в своих приложениях, но, думаю, это несложно, и с этим вы
справитесь сами.
Для ее запуска достаточно в подсказке DOS набрать ее имя и число:

CONTFRAC 3.141592654

program
contfrac; { непрерывные дроби }
{$N+}
const

order = 20;var

y,
lasterr,
error,
x : extended;

a : array[0..order]
of longint;
i,j,
n : integer;
op,
p,
q : longint;
begin

lasterr := 1e30;
val(paramstr(1), y, n);
if n <> 0 then
halt;
x := y;
a[0] := trunc(x);

writeln;
writeln(a[0]:20,
a[0]:14, 1:14);
{
это может вызвать резкую головную боль и галлюцинации }

for i := 1 to order do
begin
x := 1.0 / frac(x);
a[i] := trunc(x);
p := 1;
q := a[i];
for j := pred(i) downto 0
do begin
op := p;
p := q;
q := a[j] * q + op;
end;
error := abs(y - int(q) / int(p));
if abs(error) >= abs(lasterr) then
halt;
writeln(a[i]:20, q:14, p:14, error:10);
if error < 1e-18
then
halt;
lasterr := error;
end;end.
Категория: Алгоритмы | Добавил: Lerka (22 Ноя 2012)
Просмотров: 504 | Рейтинг: 1.0/ 4 Оштрафовать | Жаловаться на материал
Похожие материалы
Всего комментариев: 0

Для блога (HTML)


Для форума (BB-Code)


Прямая ссылка

Профиль
Понедельник
29 Апр 2024
01:13


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Главная страница
Используются технологии uCoz