|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
||||||
LONG VS DOUBLE / INT VS FLOAT11.06.2014, 12:31. Показов 2366. Ответов 19
Метки нет (Все метки)
Всем доброго времени суток!
Объясните пожалуйста почему при следующем коде
Спасибо!
0
|
||||||
| 11.06.2014, 12:31 | |
|
Ответы с готовыми решениями:
19
Напишите программу, которая будет определять размер для данных (int, char, long, double, short, unsigned, float) и выводить информацию |
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
|
| 11.06.2014, 13:01 | |
|
Это особенности поведения даблов. Суть в том, что если d = 15.99999999999 вследствие потери точности, то при выведении его как дабла, он округлится нормально, а при выведении как инта целая часть отбросится и будет 15. Приводить к целому типу лучше, прибавляя какое-нибудь небольшое число, например, 0.000000001, чтобы избежать таких потерь в точности
Добавлено через 2 минуты Вместо e = d надо сделать e = d + 0.000001. Да и static_cast<int>(b) лучше заменить на static_cast<int>(b + 0.0000001)
0
|
|
|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
|
| 11.06.2014, 13:04 [ТС] | |
|
Я думал об этом. Но если выполнить действия
a = 196 b = 196/60=3,266667 c = 3 d = (3,266667 - 3) * 60 = 16.00002 Что больше 16. Соответсвенно, если следовать Вашей версии, то ответ должен быть 16.
0
|
|
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
||||||
| 11.06.2014, 13:17 | ||||||
|
Вы не совсем правильно оцениваете точность операций. Дабл хранит, если не ошибаюсь, около 20 знаков после запятой, округляя только последний. При этом, в нескольких последних знаках могут быть ошибки. В частности,
15.999999999999996447
0
|
||||||
|
Неэпический
|
|
| 11.06.2014, 13:20 | |
|
1
|
|
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
||
| 11.06.2014, 13:21 | ||
|
0
|
||
|
327 / 230 / 55
Регистрация: 30.05.2014
Сообщений: 682
|
|
| 11.06.2014, 13:24 | |
|
0
|
|
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
||
| 11.06.2014, 13:29 | ||
|
Добавлено через 53 секунды Да и Ваш способ и для округления не годится для случая отрицательных чисел
0
|
||
|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
|||
| 11.06.2014, 13:32 [ТС] | |||
|
ЭТО РАБОТАЕТ
А более надежные способы есть? Или всегда прибавлять 0.000001 и не задумываться?
0
|
|||
|
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
|
||
| 11.06.2014, 13:38 | ||
0
|
||
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
||||||||
| 11.06.2014, 13:42 | ||||||||
Добавлено через 2 минуты
0
|
||||||||
|
327 / 230 / 55
Регистрация: 30.05.2014
Сообщений: 682
|
|||
| 11.06.2014, 13:45 | |||
|
Если надо строго вверх или вниз - fllor и ceil как уже подсказали.
0
|
|||
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
||
| 11.06.2014, 13:49 | ||
|
0
|
||
|
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
|
||
| 11.06.2014, 13:52 | ||
0
|
||
|
327 / 230 / 55
Регистрация: 30.05.2014
Сообщений: 682
|
|
| 11.06.2014, 13:54 | |
|
0
|
|
|
31 / 31 / 19
Регистрация: 03.05.2011
Сообщений: 84
|
||
| 11.06.2014, 13:59 | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
|||||||
| 11.06.2014, 16:16 [ТС] | |||||||
Добавлено через 24 минуты После мозгового штурма (спасибо всем) я написал так (оставлю здесь для истории)
long double roundl (long double x); описана тут
0
|
|||||||
|
327 / 230 / 55
Регистрация: 30.05.2014
Сообщений: 682
|
||
| 11.06.2014, 17:17 | ||
)
0
|
||
|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
||
| 11.06.2014, 22:47 [ТС] | ||
|
e = d + 0.5 Так? а если учитывать знак то все равно придется использовать функцию (модуль)? Я правильно понял? А если придется использовать функцию, то почему бы не использовать округление до ближайшего целого? Или так памяти больше тратится или время работы увеличивается? Глупости не наговорил?
0
|
||
|
327 / 230 / 55
Регистрация: 30.05.2014
Сообщений: 682
|
||
| 12.06.2014, 05:14 | ||
|
0
|
||
| 12.06.2014, 05:14 | |
|
Помогаю со студенческими работами здесь
20
Long float и double Преобразовать 2 числа int в 1 число float(double) | double int1.int2 Double, int , long double Поменять местами значения бит в заданном количестве пар бит Требуется написать функцию long long pow(long long a, unsigned int p), которая возводит число a в степень p Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|