Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Теоретические вопросы _ Погрешность типа Float

Автор: X.XaM_MaX.X 25.01.2007 1:05

Я делаю калькулятор, но в моём распоряжение только тип float(real использовать нет возможности) и я заметил что в некоторых случаях у него появляется погрешность типа такого:
h1 and h2 - float
h1=2.38
h2=32
h1+h2=34.380001
Как мне избегать эту погрешность? unsure.gif

Автор: volvo 25.01.2007 1:07

Типа Float в Паскале нет... Или ты что-то недоговариваешь, или ошибся разделом...

Автор: X.XaM_MaX.X 25.01.2007 1:11

Блин ошибся mega_chok.gif Я был уверен что он там есть wacko.gif Я вообще на другом я языке пишу, но когда у меня чего-то не получается начинаю сначала писать на паскале вот и спросил, а надо было сначало проверить если там такой тип (простите меня дурака) =( А вообще здесь мне с этим типом помогут где-нибудь? В какой раздел мне идти?

Автор: Malice 25.01.2007 1:13

Не float а single может быть? А вообще - никак. Т.к. для калькулятора особо скорость не нужна, сделай лучше числа в строках, и допиши функции для +-*/. Тогда в твоем распоряжении будет 255 знаков, огромная точность, почти никаких потерь.

Автор: X.XaM_MaX.X 25.01.2007 1:17

Ээ..перегонять их в строки потом перегонять в float(single) считать и опять перегонять в строки? Нет я точно чего-то не понял ( Можно по подробней...если не сложно...

Автор: Malice 25.01.2007 1:40

Не надо перегонять. Хранить числа в строках. Операции производить тоже со строками. Немножго геморойно по началу, но зато какая точность ! smile.gif

Автор: X.XaM_MaX.X 25.01.2007 1:50

Значит надо самому процедуры писать свои для этого?

Автор: arhimag 25.01.2007 1:53

смотри у тебя длина первого хвоста дроби 2 у второго 1 тогда выведи все с точностью до 2ого символа

Добавлено:
или проблема в чем-то другом?
также можно и с результатом, обрезаем дробь до максималоьной длины хвоста и заново присваиваем
для этого придется написать процедуру перевода строки в реал

Автор: klem4 25.01.2007 2:23

Цитата
придется написать процедуру перевода строки в реал


Str уже не устраивает ?