63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
1

double в int

25.11.2013, 17:55. Показов 64485. Ответов 31
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
собственно вопрос в шапке, как перевести double в int? т.е. также как работает делфийская функция round, округлить до целых и выдать число в формате int
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
25.11.2013, 17:55
Ответы с готовыми решениями:

Преобразовать 2 числа int в 1 число float(double) | double int1.int2
Всем привет. Изучая азы C++, столкнулся с такой проблемой. Есть два значения типа int, их...

Double, int , long double
Как вычислить диапазоны типов вручную указанных в название темы?

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

int и double
//--------------------------------------------------------------------------- #include "math.h"...

31
погромист
415 / 251 / 30
Регистрация: 27.08.2012
Сообщений: 550
25.11.2013, 19:57 21
Author24 — интернет-сервис помощи студентам
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Что не удивительно, т.к. в С++, в отличие от Delphi, нету функции round.
http://en.cppreference.com/w/c... math/round
0
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
25.11.2013, 20:01  [ТС] 22
Цитата Сообщение от coloc Посмотреть сообщение
хз хз "error C3861: round: идентификатор не найден", cmath проинклуден
0
46 / 46 / 18
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 20:02 23
Эм.. возможно, я не прав. Но меня всю жизнь учили, что округляют до ближайшего целого. По-вашему 0.49 ближе к 1, чем к нулю?
И всё-же попрошу товарищей разъяснить ситуацию. Кто здесь прав ?
0
погромист
415 / 251 / 30
Регистрация: 27.08.2012
Сообщений: 550
25.11.2013, 20:04 24
GetHelp, хз хз читать надо since C++11
0
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
25.11.2013, 20:08  [ТС] 25
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Эм.. возможно, я не прав. Но меня всю жизнь учили, что округляют до ближайшего целого. По-вашему 0.49 ближе к 1, чем к нулю?
И всё-же попрошу товарищей разъяснить ситуацию. Кто здесь прав ?
1,49 округляют насколько меня в школе учили так: начинаем с 9, т.к. всегда при округлении если число больше или равно 5, то округлять в большую сторону, значит 1 переносится в следующий разряд, получается 1,5, а 1,5 уже по тому же правилу округляем и получаем 2...

Добавлено через 2 минуты
Цитата Сообщение от coloc Посмотреть сообщение
GetHelp, хз хз читать надо since C++11
че то вообще не понял смысл поста... что "С++11"? в смысле у меня студия чтоли не та стоит? ну тут я уж ниче не могу поделать, ради этого переустанавливать влом...
0
46 / 46 / 18
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 20:12 26
Всё еще жду чьих-то отзывов. Всё равно считаю, что правильным является мой вариант.

Не по теме:

Цитата Сообщение от GetHelp Посмотреть сообщение
че то вообще не понял смысл поста... что "С++11"?
C++11[1][2] или ISO/IEC 14882:2011[3] (в процессе работы над стандартом носил условное наименование C++0x[4][5]) — новая версия стандарта языка C++, вместо ранее действовавшего ISO/IEC 14882:2003. Новый стандарт включает дополнения в ядре языка и расширение стандартной библиотеки, в том числе большую часть TR1 — кроме, вероятно, библиотеки специальных математических функций.

1
1130 / 789 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
25.11.2013, 20:15 27
GetHelp,
Цитата Сообщение от GetHelp Посмотреть сообщение
даже не 1,75, а например попробуйте взять 1,45 или 1,49 и получите 1, а по правилам математики должно выходить 2...
Если 1,45 то scanf() считывает только один знак ( доходит до запятой и останавливается ). Вы добавьте, чтобы было видно, что прочитали.
C++
1
printf( "Read:  %d     Result: %d  ", a, b );
Кроме того, это ещё зависит от setlocale() - надо ли вводить 1.23 или 1,23 ( с точкой или с запятой ).
C++
1
2
3
4
5
6
7
8
9
10
11
12
    {
        float x = 0.0;
        char* loc = setlocale( 0, "" );
        printf( "\n locale : %s \n", loc );
        scanf("%f", &x);
        printf("input: %f   round: %i\n", x, round(x));
 
        loc = setlocale( 0, "C" );
        printf( "\n locale : %s \n", loc );
        scanf("%f", &x);
        printf("input: %f   round: %i\n", x, round(x));
    }
Миниатюры
double в int  
0
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
25.11.2013, 20:27  [ТС] 28
Alex5, (10 символов)
Миниатюры
double в int  
0
36 / 23 / 10
Регистрация: 14.11.2013
Сообщений: 85
25.11.2013, 20:32 29
Цитата Сообщение от GetHelp Посмотреть сообщение
1,49 округляют насколько меня в школе учили так: начинаем с 9, т.к. всегда при округлении если число больше или равно 5, то округлять в большую сторону, значит 1 переносится в следующий разряд, получается 1,5, а 1,5 уже по тому же правилу округляем и получаем 2...
|1,49 - 1| = 0,49
|1,49 - 2| = 0,51

Расстояние от точки 1,49 до 1 меньше, чем до 2. Значит 1,49 ≈ 1

Добавлено через 4 минуты
Цитата Сообщение от GetHelp Посмотреть сообщение
ахаха жжете товарищ ! давайте так: вы сейчас идете и открываете учебник математики за 5 (примерно) класс и внимательно читаете как по правилам делать округление...
Учебник придется именно Вам открывать!
0
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
25.11.2013, 20:36  [ТС] 30
http://ru.wikipedia.org/wiki/Округление

Добавлено через 1 минуту
"Во всех вариантах в случае, когда (N+1)-й знак не равен 5 или последующие знаки не равны нулю, округление происходит по обычным правилам: 2,49 → 2; 2,51 → 3."

блин это бардак, кажется я всю жизнь не правильно округлял
0
46 / 46 / 18
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 20:37 31
Цитата Сообщение от GetHelp Посмотреть сообщение
http://ru.wikipedia.org/wiki/Округление
Округление к ближайшему целому (англ. rounding) — наиболее часто используемое округление, при котором число округляется до целого, модуль разности с которым у этого числа минимален.
Что и описал LuxArt.
0
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
25.11.2013, 20:56  [ТС] 32
так ладно, я короче разочаровался в математике раз уж меня в школе не правильно научили...

в общем еще такое дело, кто нибудь может привести функцию округления до заданного разряда? т.е. например до десятых или сотых и т.д.

Добавлено через 3 минуты
а нет отбой сори, кажется тут это не нужно, перестарался... хотя такую функцию все равно интерестно было бы увидеть
0
25.11.2013, 20:56
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
25.11.2013, 20:56
Помогаю со студенческими работами здесь

double и int
double buf = Convert::ToDouble(pole->Text);//Обьявляем переиенную buf switch (regim) {...

Не int, а double
Как сделать чтобы код принимал дробовые значения, а не целые и в ответ тоже записывал дробь....

2 int to double
Здравствуйте. Вот такой вопрос. В памяти хранится 2 int числа - рубли и копейки, при выводе...

int* to double*
double* myDoublePtr; int myInt = 5; int* myIntPtr; myIntPtr = &myInt; // cout...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru