|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
||||||
LONG VS DOUBLE / INT VS FLOAT11.06.2014, 12:31. Показов 2342. Ответов 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 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать контроль заполнения реквизита табличной части. . .
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
|
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|