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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.88
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
#1

double в int - C++

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

собственно вопрос в шапке, как перевести double в int? т.е. также как работает делфийская функция round, округлить до целых и выдать число в формате int
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.11.2013, 17:55
Здравствуйте! Я подобрал для вас темы с ответами на вопрос double в int (C++):

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

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

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

int* to double* - C++
double* myDoublePtr; int myInt = 5; int* myIntPtr; myIntPtr = &myInt; // cout << "myIntPtr: " << myIntPtr << " "...

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

int и double - C++
//--------------------------------------------------------------------------- #include "math.h" #include <stdio.h> #include...

31
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 19:34  [ТС] #16
логика мягко говоря странная, а что вы будете делать если у числа больше 1 знака за запятой? скажем 1,75
0
scenotaph
120 / 120 / 15
Регистрация: 29.03.2013
Сообщений: 237
25.11.2013, 19:35 #17
GetHelp, Да потому что не 1,75 а 1.75, наверное?
0
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 19:40  [ТС] #18
Цитата Сообщение от scenotaph Посмотреть сообщение
GetHelp, Да потому что не 1,75 а 1.75, наверное?
оо... да вот теперь выдает 2 действительно... хотя я и не понимаю почему оно тогда не чекнуло мне ошибку при считывании если запятая вместо точки на это влияет? и по прежнему логика у функции странная (предыдущий пост)

Добавлено через 2 минуты
даже не 1,75, а например попробуйте взять 1,45 или 1,49 и получите 1, а по правилам математики должно выходить 2...
0
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 19:54 #19
GetHelp, при 1.45 и 1.49 по правилам должно быть 1. При округлении до целого берётся во внимание только десятичное. Сотые не влияют.
При считывании не выдало ошибку потому, что считало только 1.
0
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 19:56  [ТС] #20
Цитата Сообщение от Hunter13ua Посмотреть сообщение
GetHelp, при 1.45 и 1.49 по правилам должно быть 1. При округлении до целого берётся во внимание только десятичное. Сотые не влияют.
При считывании не выдало ошибку потому, что считало только 1.
ахаха жжете товарищ ! давайте так: вы сейчас идете и открываете учебник математики за 5 (примерно) класс и внимательно читаете как по правилам делать округление...
0
coloc
погромист
410 / 246 / 15
Регистрация: 27.08.2012
Сообщений: 550
Завершенные тесты: 1
25.11.2013, 19:57 #21
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Что не удивительно, т.к. в С++, в отличие от Delphi, нету функции round.
http://en.cppreference.com/w/cpp/numeric/math/round
0
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:01  [ТС] #22
хз хз "error C3861: round: идентификатор не найден", cmath проинклуден
0
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 20:02 #23
Эм.. возможно, я не прав. Но меня всю жизнь учили, что округляют до ближайшего целого. По-вашему 0.49 ближе к 1, чем к нулю?
И всё-же попрошу товарищей разъяснить ситуацию. Кто здесь прав ?
0
coloc
погромист
410 / 246 / 15
Регистрация: 27.08.2012
Сообщений: 550
Завершенные тесты: 1
25.11.2013, 20:04 #24
GetHelp, хз хз читать надо since C++11
0
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
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
Hunter13ua
46 / 46 / 5
Регистрация: 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
Alex5
1072 / 736 / 114
Регистрация: 12.04.2010
Сообщений: 1,883
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));
    }
0
Миниатюры
double в int  
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:27  [ТС] #28
Alex5, (10 символов)
0
Миниатюры
double в int  
LuxArt
34 / 21 / 2
Регистрация: 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
GetHelp
-7 / 61 / 6
Регистрация: 27.02.2013
Сообщений: 1,112
25.11.2013, 20:36  [ТС] #30
http://ru.wikipedia.org/wiki/Округление

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

блин это бардак, кажется я всю жизнь не правильно округлял
0
25.11.2013, 20:36
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.11.2013, 20:36
Привет! Вот еще темы с ответами:

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

float double int - C++
Доброй ночи, препод совсем запарил, то ему не так, то ему не эдак. // 8.2.cpp: определяет точку входа для консольного приложения. // ...

Перевести double в int - C++
Как перевести значения типа double (после логарифмического преобразования) в int?

cannot convert from 'int *' to 'double *' - C++
Помогите пожалуйста исправить ошибку: error C2440: '=' : cannot convert from 'int *' to 'double *'. #include <iostream.h> void...


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

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

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