Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Операции с числами, Автоматическое округление чисел  
:(
    Опции темы
cadet05
Дата 11.3.2011, 11:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 6.1.2011

Репутация: нет
Всего: нет



При больших значениях целой части числа с плавающей точкой его дробная часть автоматически округляется до некоторого значения.
Например:
1.
cout << 0.7851+0.3297
на выходе получается 1.1148.
Здесь вопросов нет.

2. 
cout << 100.7851+100.3297
на выходе получается 201.115.
Произошло округление числа 201.1148 до тысячных.

Кто-нибудь знает, как этого избежать?
PM MAIL   Вверх
RastaDja
Дата 11.3.2011, 12:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 337
Регистрация: 1.11.2010

Репутация: нет
Всего: 5



Цитата(cadet05 @  11.3.2011,  11:15 Найти цитируемый пост)
При больших значениях целой части числа с плавающей точкой его дробная часть автоматически округляется до некоторого значения.


нет это не так, ничего не округляется в результируемом згачении. Округление происходит при вызове cout.

попробуйте так
Код

#include <iomanip>//это важно

std::cout<< std::setprecision(10) << 100.7851+100.3297;





--------------------
The more closely you look at one thing, the less closely can you see something else.
PM MAIL   Вверх
baldina
Дата 11.3.2011, 12:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3433
Регистрация: 5.12.2007
Где: Москва

Репутация: 32
Всего: 101



Цитата(cadet05 @  11.3.2011,  11:15 Найти цитируемый пост)
Кто-нибудь знает, как этого избежать? 

чего именно?

по умолчанию при форматировании вывода double в поток учитывается число значащих цифр
если нужно число после запятой, а не число значащих, надо использовать fixed или scientific
число цифр в обоих случаях устанавливается при помощи ios_base::precision() или setprecision()
http://www.cplusplus.com/reference/iostrea...ors/scientific/

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0699 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.