Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
25 / 25 / 5
Регистрация: 21.04.2011
Сообщений: 141
1

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

16.07.2012, 15:34. Просмотров 1962. Ответов 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. Куда делась единица?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.07.2012, 15:34
Ответы с готовыми решениями:

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

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

Ошибки error C2296: -: недопустимо, левый операнд имеет тип "double (__cdecl *)(double,double,double
Думаю из-за polp #include&lt;iostream&gt; #include&lt;cmath&gt; #include&lt;cstdlib&gt; using namespace std;...

Доступны ли побитовые операции с unsigned char типом (одно-байтовой переменной) без неявного приведения к INT
Отказавшись от bitset мне удалось ускорить работу программы примерно в 2,25 раза Вот её код (ребят...

9
21 / 17 / 4
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 15:49 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;
}
1
1450 / 787 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
16.07.2012, 15:52 3
Правильный компилятор должен вас предупредить: warning C4244: инициализация: преобразование "double" в "int", возможна потеря данных
0
25 / 25 / 5
Регистрация: 21.04.2011
Сообщений: 141
16.07.2012, 15:58  [ТС] 4
Да точно, предупреждение было, теперь правильно работает.
Только я не понял чем отличается запись (tN-t)/h от tN/h-t/h
0
21 / 17 / 4
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:01 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
Это получилось методом тыка, почему так работает, а по старой схеме нет - я не знаю
0
Делаю внезапно и красиво
Эксперт С++
1309 / 1224 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
16.07.2012, 16:11 6
Цитата Сообщение от Fooly Посмотреть сообщение
C++
1
2
3
for (int i=0; i<100; i++)
 cin.get();
 return 0;
ЛОЛ што?
0
21 / 17 / 4
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:20 7
Цитата Сообщение от Deviaphan Посмотреть сообщение
ЛОЛ што?
У меня при нажатии Enter консоль закрывается, таким способом я борюсь с этим Наверное можно использовать system("pause"), но я привык уже так. Я только начал читать книжки по с++, поэтому не знаю нюансов, как-то приходится выкручиваться, хоть и через попу всё выходит
0
Эксперт С++
2919 / 1268 / 114
Регистрация: 27.05.2008
Сообщений: 3,465
16.07.2012, 16:21 8
Цитата Сообщение от Fooly Посмотреть сообщение
Ёлки-палки, если приводить double к int, значение уменьшается на 1 А почему так? Ведь Nt получается равным 20, а Ht уже 19. Интересненько...
Все довольно тривиально. Причина в конечной точности представления чисел с плавающей точкой в компьютере.

Не проверял, но по-видимому, в результате вычисления получается величина похожая на 19.99999..... - с точки зрения человека это "почти 20", но с точки зрения компьютера - до ровно 20 все-таки не дотягивает, и при преобразовании к int дробная часть будет отброшена, поэтому и получен законный результат 19.
0
Делаю внезапно и красиво
Эксперт С++
1309 / 1224 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
16.07.2012, 16:21 9
Тогда хотя бы cin.get();cin.get();
0
21 / 17 / 4
Регистрация: 26.03.2012
Сообщений: 147
16.07.2012, 16:26 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 нажатия
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.07.2012, 16:26

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Ошибка: error LNK2001: unresolved external symbol "double __cdecl Akk(double,double,double)"
#include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; double Akk(double x, double y, double...

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

Арифметические операции с типом double и непонятная погрешность
Столкнулся с такой проблемой: у меня идет цикл с переменной типа double for (double j = bottom;...

Происходит добавление маленького числа к результату с типом Double
Здравствуйте! При сложении двух чисел типа double иногда происходит добавление очень малого числа к...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

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