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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
MAnton
23 / 23 / 1
Регистрация: 21.04.2011
Сообщений: 139
#1

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

16.07.2012, 15:34. Просмотров 718. Ответов 9
Метки нет (Все метки)

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. Куда делась единица?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.07.2012, 15:34     Операции с типом double
Посмотрите здесь:

Может ли переменная-счетчик быть типом Double - C++
Может ли быть счетчик оператора for, while и т. д. ( у меня это FR1 и массив MFR) задан типом данных double ? У меня ругается и только int...

Как написать функцию c типом long double возвращаюшую тип shot? - C++
Мне бы какой нибудь тривиальный пример в Си. Спасибо:)

В чем разница между типом функции и типом возвращаемого значения? - C++
Читаю статью https:// code-live. ru/post/cpp-functions/ (ссылку изменил дабы не делать рекламу) Там написано - Любая функция...

Метод за типом класса - C++
Объясните вот эту строку: dist3 = dist1.add_dist(dist2); и эту: Distance Distance::add_dist(Distance d2)

Задача с булевым типом - C++
Здраствуйте! :) Вот над задачей уже третий день голову ламаю: Имеются три числа А,В,С.Нужно вывести на экран false если больше чем одно из...

работа с файловым типом((( - C++
Выступление каждого спортсмена независимо оценивается несколькими судьями, затем из всей совокупности оценок удаляются наиболее высокая и...

Работа с типом char - C++
Пожалуйста, помогите понять разницу между этими записями: char a; char *a; char *a; char a;

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
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
1429 / 766 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
16.07.2012, 15:52     Операции с типом double #3
Правильный компилятор должен вас предупредить: warning C4244: инициализация: преобразование "double" в "int", возможна потеря данных
MAnton
23 / 23 / 1
Регистрация: 21.04.2011
Сообщений: 139
16.07.2012, 15:58  [ТС]     Операции с типом double #4
Да точно, предупреждение было, теперь правильно работает.
Только я не понял чем отличается запись (tN-t)/h от tN/h-t/h
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++
1286 / 1220 / 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
21 / 17 / 1
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:20     Операции с типом double #7
Цитата Сообщение от Deviaphan Посмотреть сообщение
ЛОЛ што?
У меня при нажатии Enter консоль закрывается, таким способом я борюсь с этим Наверное можно использовать system("pause"), но я привык уже так. Я только начал читать книжки по с++, поэтому не знаю нюансов, как-то приходится выкручиваться, хоть и через попу всё выходит
CheshireCat
Эксперт С++
2892 / 1241 / 78
Регистрация: 27.05.2008
Сообщений: 3,353
16.07.2012, 16:21     Операции с типом double #8
Цитата Сообщение от Fooly Посмотреть сообщение
Ёлки-палки, если приводить double к int, значение уменьшается на 1 А почему так? Ведь Nt получается равным 20, а Ht уже 19. Интересненько...
Все довольно тривиально. Причина в конечной точности представления чисел с плавающей точкой в компьютере.

Не проверял, но по-видимому, в результате вычисления получается величина похожая на 19.99999..... - с точки зрения человека это "почти 20", но с точки зрения компьютера - до ровно 20 все-таки не дотягивает, и при преобразовании к int дробная часть будет отброшена, поэтому и получен законный результат 19.
Deviaphan
Делаю внезапно и красиво
Эксперт C++
1286 / 1220 / 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
Еще ссылки по теме:

Ошибка с типом char - C++
При запуске выдает ошибки связанные с char. На другой версии visual все работало сразу. Не понимаю как исправить их. Ошибки выделены в...

Работа с символьным типом - C++
Код:// ex10_4.cpp #include &lt;iostream&gt; using namespace std; //////////////////////////////////////////////////////////////// struct...

Строки с типом char * в С++ - C++
Помогите написать программу по строкам c++ При написании программ использовать нуль–терминированные строки и работать только с типом...

Asterisk с типом / с именем ? - C++
Парни, у меня тупой вопрос(мне уже стыдно), а так же потенциальная возможность профессионалу легко заработать &quot;лучший ответ&quot; в копилку...

Функция с типом bool - C++
Добрый день! Есть функция main в которой надо вызвать другую функцию ( bool Simple с переменной int ), которая выводит является ли...


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

Или воспользуйтесь поиском по форуму:
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
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru