74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
|
|
1 | |
Округление double20.10.2011, 22:45. Показов 8355. Ответов 15
Метки нет (Все метки)
Короче ввожу число 1.05
в Debug показывает его, как 1.004999999999999999995663191310058 вот как эту чушь убрать, у меня задача из-за этого не решается?
0
|
20.10.2011, 22:45 | |
Ответы с готовыми решениями:
15
Округление double Округление Double Округление Long double. Убрать округление double |
Заблокирован
|
|
20.10.2011, 22:52 | 2 |
если дробная часть не является степенью с основанием 2, то машина будит не в состоянии запомнить его без погрешности.
Либо запоминай дробь в виде двух чисел, либо в видет текста, либо учитывай погрешность. Дробные числва нельзя сравнивать друг с другом. Можно сравнивать лишь разность этих чисел с погрешностью. if(a-b< p) { /*считать числа a и b равными*/ } где p - очень маленькое число, и гарантированно, что это незначительное расхождение между а и б - допустимое что бы считать их равными
0
|
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
|
||||||
20.10.2011, 23:00 [ТС] | 3 | |||||
Ну тогда уж сразу помогите с реализацией задачи
считывают 3 числа: A,B,C типа double надо вывести, сколько раз k*A/B является целым(k*A<C), где k - переменная, увеличивающаяся на 1 при каждой проверке У меня проверялось,
0
|
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
|
||||||
21.10.2011, 19:20 | 5 | |||||
Если числа надо сравнивать, то по возможности следует использовать целочисленные типы. Но если уж числа изначально дробные и представлены типом double, то обычно проверяют модуль их разности на превышение некого разумного порога.
1
|
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
|
|
21.10.2011, 19:43 | 8 |
Зато ошибка представления числа при делении почти не зависит от абсолютного значения, так как в этом случае она получается почти в буквальном смысле относительной. Но тут ещё надо будет икс на ноль проверять.
0
|
7175 / 3234 / 81
Регистрация: 17.06.2009
Сообщений: 14,164
|
||||||
21.10.2011, 19:51 | 9 | |||||
Не ясно условие задачи
Почему сравнивается именно с C/B, если нужно получить целое число ? Вообще говоря пусть double t= k*A/B; Нужно проверить что t - целое число Так как полного совпадения с целым добиться крайне трудно то будем проверять что число t является целым с какой-то точностью eps ( eps= 0.001 ) Для простоты предположим что A>0, B>0, C>0 Тогда целая часть t - это floor(t) Дробная часть t - это t-floor(t) Нам нужно проверить что дробная часть t меньше eps Условие такое: if ( fabs( t-floor(t) )<eps ) ... Добавлено через 3 минуты Код примерное такой
0
|
Заблокирован
|
|
21.10.2011, 19:53 | 10 |
я брал за погрешность const double ESP=0.0000001;
И никада не парился. Этой погрешности и простого вычитания достаточно, что бы безошибочно запоминать числа от -999999999.999999 до 999999999.999999 (использовал при написании велосипеда, который переводит символьное представление дробного числа в double и обратно. Аналоги из стандартной библиотеки работают с такой же максимальной точностью).
0
|
7175 / 3234 / 81
Регистрация: 17.06.2009
Сообщений: 14,164
|
||||||
21.10.2011, 19:57 | 11 | |||||
Код
> 1.exe 1 7 100 0.000001 k=0 t=0.000000 k=7 t=1.000000 k=14 t=2.000000 k=21 t=3.000000 k=28 t=4.000000 k=35 t=5.000000 k=42 t=6.000000 k=49 t=7.000000 k=56 t=8.000000 k=63 t=9.000000 k=70 t=10.000000 k=77 t=11.000000 k=84 t=12.000000 k=91 t=13.000000 k=98 t=14.000000 answer=15
0
|
-1 / 2 / 0
Регистрация: 20.10.2011
Сообщений: 18
|
|
21.10.2011, 20:20 | 12 |
if ( fmod(k*a, b) == 0 ) { /*если k*a делится на b без остачи чтото делаем*/ }
Добавлено через 11 минут А если с учотом погрешности, то пиши if(fmod(k*a, b) < 0.000001 ) { /*если k*a делится на b без остачи чтото делаем*/ }
0
|
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
|
||||||
21.10.2011, 22:54 [ТС] | 13 | |||||
Из-за чего это может быть? Предел числам не указан
0
|
Заблокирован
|
|||||||
21.10.2011, 22:55 | 14 | ||||||
по кнопкам быстрее щёлкать нада))
0
|
7175 / 3234 / 81
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
22.10.2011, 09:40 | 15 |
0
|
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
|
|
23.10.2011, 19:15 [ТС] | 16 |
да. В основу берётся проверка деления нацело десятичных дробей. Только в этом проблема.
До сих пор не могу решить её(
0
|
23.10.2011, 19:15 | |
23.10.2011, 19:15 | |
Помогаю со студенческими работами здесь
16
double округление с точность до N знаков Форматирование вывода и округление double Округление числа double до десятых, до сотых printf. Округление чисел типа double Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |