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

double в int - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.88
GetHelp
-8 / 60 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 17:55     double в int #1
собственно вопрос в шапке, как перевести double в int? т.е. также как работает делфийская функция round, округлить до целых и выдать число в формате int
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.11.2013, 17:55     double в int
Посмотрите здесь:

cannot convert from 'int *' to 'double *' C++
C++ double и int
C++ int и double
2 int to double C++
Double, int , long double C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
coloc
погромист
 Аватар для coloc
409 / 245 / 15
Регистрация: 27.08.2012
Сообщений: 550
Завершенные тесты: 1
25.11.2013, 19:57     double в int #21
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Что не удивительно, т.к. в С++, в отличие от Delphi, нету функции round.
http://en.cppreference.com/w/cpp/numeric/math/round
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
GetHelp
-8 / 60 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:01  [ТС]     double в int #22
хз хз "error C3861: round: идентификатор не найден", cmath проинклуден
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 20:02     double в int #23
Эм.. возможно, я не прав. Но меня всю жизнь учили, что округляют до ближайшего целого. По-вашему 0.49 ближе к 1, чем к нулю?
И всё-же попрошу товарищей разъяснить ситуацию. Кто здесь прав ?
coloc
погромист
 Аватар для coloc
409 / 245 / 15
Регистрация: 27.08.2012
Сообщений: 550
Завершенные тесты: 1
25.11.2013, 20:04     double в int #24
GetHelp, хз хз читать надо since C++11
GetHelp
-8 / 60 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:08  [ТС]     double в int #25
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Эм.. возможно, я не прав. Но меня всю жизнь учили, что округляют до ближайшего целого. По-вашему 0.49 ближе к 1, чем к нулю?
И всё-же попрошу товарищей разъяснить ситуацию. Кто здесь прав ?
1,49 округляют насколько меня в школе учили так: начинаем с 9, т.к. всегда при округлении если число больше или равно 5, то округлять в большую сторону, значит 1 переносится в следующий разряд, получается 1,5, а 1,5 уже по тому же правилу округляем и получаем 2...

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

Не по теме:

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

Alex5
883 / 618 / 81
Регистрация: 12.04.2010
Сообщений: 1,552
25.11.2013, 20:15     double в int #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  
GetHelp
-8 / 60 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:27  [ТС]     double в int #28
Alex5, (10 символов)
Миниатюры
double в int  
LuxArt
33 / 20 / 2
Регистрация: 14.11.2013
Сообщений: 85
25.11.2013, 20:32     double в int #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 (примерно) класс и внимательно читаете как по правилам делать округление...
Учебник придется именно Вам открывать!
GetHelp
-8 / 60 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:36  [ТС]     double в int #30
http://ru.wikipedia.org/wiki/Округление

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

блин это бардак, кажется я всю жизнь не правильно округлял
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 20:37     double в int #31
Цитата Сообщение от GetHelp Посмотреть сообщение
http://ru.wikipedia.org/wiki/Округление
Округление к ближайшему целому (англ. rounding) — наиболее часто используемое округление, при котором число округляется до целого, модуль разности с которым у этого числа минимален.
Что и описал LuxArt.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.11.2013, 20:56     double в int
Еще ссылки по теме:

float double int C++
перевести double в int C++
C++ int* to double*

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

Или воспользуйтесь поиском по форуму:
GetHelp
-8 / 60 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:56  [ТС]     double в int #32
так ладно, я короче разочаровался в математике раз уж меня в школе не правильно научили...

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

Добавлено через 3 минуты
а нет отбой сори, кажется тут это не нужно, перестарался... хотя такую функцию все равно интерестно было бы увидеть
Yandex
Объявления
25.11.2013, 20:56     double в int
Ответ Создать тему
Опции темы

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