Форум программистов, компьютерный форум CyberForum.ru

Операции с типом double - C++

Восстановить пароль Регистрация
 
MAnton
 Аватар для MAnton
23 / 23 / 1
Регистрация: 21.04.2011
Сообщений: 139
16.07.2012, 15:34     Операции с типом double #1
C++ (Qt)
1
2
3
4
5
    double h=0.005;
    double T=0.2;
    double tN=0.3;
    int Nt=(tN-T)/h;
    cout<<"Nt "<<Nt<<endl;
На экран выводится 19, при h=0.0005 выводит 199. Куда делась единица?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Fooly
 Аватар для Fooly
21 / 17 / 1
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 15:49     Операции с типом double #2
Так будет работать правильно
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
using namespace std;
int main()
{
    double h=0.005;
    double T =0.2;
    double tN=0.3;
    int Nt=tN/h-T/h;
    cout<<"Nt "<<Nt<<endl;
    for (int i=0; i<100; i++)
        cin.get();
    return 0;
}
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
16.07.2012, 15:52     Операции с типом double #3
Правильный компилятор должен вас предупредить: warning C4244: инициализация: преобразование "double" в "int", возможна потеря данных
MAnton
 Аватар для MAnton
23 / 23 / 1
Регистрация: 21.04.2011
Сообщений: 139
16.07.2012, 15:58  [ТС]     Операции с типом double #4
Да точно, предупреждение было, теперь правильно работает.
Только я не понял чем отличается запись (tN-t)/h от tN/h-t/h
Fooly
 Аватар для Fooly
21 / 17 / 1
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:01     Операции с типом double #5
Ёлки-палки, если приводить double к int, значение уменьшается на 1 А почему так? Ведь Nt получается равным 20, а Ht уже 19. Интересненько...
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <iostream>
using namespace std;
int main()
{
    double h=0.005;
    double T =0.2;
    double tN=0.3;
    double Nt=(tN-T)/h;
    int Ht =(int) Nt;
    cout<<Nt << " " <<Ht<<endl;
    for (int i=0; i<100; i++)
        cin.get();
    return 0;
}
Добавлено через 1 минуту
Цитата Сообщение от MAnton Посмотреть сообщение
Да точно, предупреждение было, теперь правильно работает.
Только я не понял чем отличается запись (tN-t)/h от tN/h-t/h
Это получилось методом тыка, почему так работает, а по старой схеме нет - я не знаю
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.07.2012, 16:11     Операции с типом double #6
Цитата Сообщение от Fooly Посмотреть сообщение
C++
1
2
3
for (int i=0; i<100; i++)
 cin.get();
 return 0;
ЛОЛ што?
Fooly
 Аватар для Fooly
21 / 17 / 1
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:20     Операции с типом double #7
Цитата Сообщение от Deviaphan Посмотреть сообщение
ЛОЛ што?
У меня при нажатии Enter консоль закрывается, таким способом я борюсь с этим Наверное можно использовать system("pause"), но я привык уже так. Я только начал читать книжки по с++, поэтому не знаю нюансов, как-то приходится выкручиваться, хоть и через попу всё выходит
CheshireCat
Эксперт С++
2907 / 1235 / 78
Регистрация: 27.05.2008
Сообщений: 3,309
16.07.2012, 16:21     Операции с типом double #8
Цитата Сообщение от Fooly Посмотреть сообщение
Ёлки-палки, если приводить double к int, значение уменьшается на 1 А почему так? Ведь Nt получается равным 20, а Ht уже 19. Интересненько...
Все довольно тривиально. Причина в конечной точности представления чисел с плавающей точкой в компьютере.

Не проверял, но по-видимому, в результате вычисления получается величина похожая на 19.99999..... - с точки зрения человека это "почти 20", но с точки зрения компьютера - до ровно 20 все-таки не дотягивает, и при преобразовании к int дробная часть будет отброшена, поэтому и получен законный результат 19.
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.07.2012, 16:21     Операции с типом double #9
Тогда хотя бы cin.get();cin.get();
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.07.2012, 16:26     Операции с типом double
Еще ссылки по теме:

Почему перестает работать программа при замене double на long double? C++
Преобразовать 2 числа int в 1 число float(double) | double int1.int2 C++
Почему мы пишем double x (double y)? а не через запятую double x,y C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Fooly
 Аватар для Fooly
21 / 17 / 1
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:26     Операции с типом double #10
Цитата Сообщение от CheshireCat Посмотреть сообщение
Все довольно тривиально. Причина в конечной точности представления чисел с плавающей точкой в компьютере.

Не проверял, но по-видимому, в результате вычисления получается величина похожая на 19.99999..... - с точки зрения человека это "почти 20", но с точки зрения компьютера - до ровно 20 все-таки не дотягивает, и при преобразовании к int дробная часть будет отброшена, поэтому и получен законный результат 19.
Но программа выводит Nt=20, а не 19.(9). А Nt это же double, должно было бы выводить 19.(9)

Добавлено через 1 минуту
Цитата Сообщение от Deviaphan Посмотреть сообщение
Тогда хотя бы cin.get();cin.get();
В таком случае консоль закрывается после 2 нажатий, а в моём только после 100 А в задачках из книги нужно больше, чем 2 нажатия

Добавлено через 10 секунд
Цитата Сообщение от Deviaphan Посмотреть сообщение
Тогда хотя бы cin.get();cin.get();
В таком случае консоль закрывается после 2 нажатий, а в моём только после 100 А в задачках из книги нужно больше, чем 2 нажатия
Yandex
Объявления
16.07.2012, 16:26     Операции с типом double
Ответ Создать тему
Опции темы

Текущее время: 12:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru