|
0 / 0 / 0
Регистрация: 11.06.2014
Сообщений: 5
|
||||||
LONG VS DOUBLE / INT VS FLOAT11.06.2014, 12:31. Показов 2293. Ответов 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 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи
и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|