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

Округление числа double до десятых, до сотых - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 34, средняя оценка - 4.97
GBIT
 Аватар для GBIT
11 / 11 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 22:34     Округление числа double до десятых, до сотых #1
Приветствую всех,

C++
1
double y=3.1415;
нужно округлить y до десятых и сотых, записать в переменные соответственно.
т.е. получить 0.1 и 0.14

наверняка есть функция типа:
округленное число = округление(округляемое_число, точность_дробной_части);

в поиске нашел округление только до целых
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.06.2013, 22:34     Округление числа double до десятых, до сотых
Посмотрите здесь:

Округление Long double. C++
C++ округление числа до десятых
double округление с точность до N знаков C++
Округление double C++
Округление до сотых. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ViktorKozlov
133 / 125 / 2
Регистрация: 13.12.2012
Сообщений: 293
03.06.2013, 22:46     Округление числа double до десятых, до сотых #2
Их нельзя округлить, у таких чисел, по сути, бесконечная дробь, можно только вывести первые несколько чисел после точки. Попробуйте, например, запустить это
C++
1
2
3
4
5
6
7
8
9
10
#include <iostream>
#include <iomanip>
 
void main()
{
    std::cout<<std::fixed<<std::setprecision(30);
 
    double y=3.1415;
    std::cout<<y<<std::endl;
}
и убедитесь, что даже это число на самом деле не совпадает с тем, которое записано, и имеет небольшую погрешность

Добавлено через 3 минуты
Как вариант, можно умножить это число на 10 или 100, округлить до целого и потом опять разделить и привести к вещественному
gray_fox
What a waste!
 Аватар для gray_fox
1244 / 1127 / 53
Регистрация: 21.04.2012
Сообщений: 2,350
Завершенные тесты: 3
03.06.2013, 22:52     Округление числа double до десятых, до сотых #3
GBIT, во-первых, сама по себе погрешность в представлении числа с плавающей точкой почти всегда будет, поиск по сайту выдаёт такое, например: http://www.cyberforum.ru/blogs/18334/blog507.html .
Genn55
341 / 188 / 37
Регистрация: 26.12.2012
Сообщений: 658
03.06.2013, 23:01     Округление числа double до десятых, до сотых #4
Можно попробовать так


C++
1
2
3
4
5
6
7
8
9
#include <iostream>
 
 int main()
{
    
 
    double y=floor (3.1415) * 100 + 0.5) / 100;
    std::cout<<y<<std::endl;
}
GBIT
 Аватар для GBIT
11 / 11 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 23:27  [ТС]     Округление числа double до десятых, до сотых #5
ViktorKozlov, каш код выводит на экран, а мне в переменные вписать нужно.
Цитата Сообщение от ViktorKozlov Посмотреть сообщение
Как вариант, можно умножить это число на 10 или 100, округлить до целого и потом опять разделить и привести к вещественному
вот я пока только такой вариант решения и нашел

поясню, что вообще творю: у меня есть угол в градусах, нужно перевести его в минуты и секунды. Вот такое пока что наваял
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
struct dms
{
    int     grad;
    int     min;
    int     sec;
};
 
dms DmsConverter(double angle)
{
dms     myAngle;
double  x,y;
 
    x = modf(/*angle*/3.14,&y);
    myAngle.grad = y;
    myAngle.min = (static_cast<int>(x*10 + 0.5) )*6;
    myAngle.sec = static_cast<int>(( (static_cast<int>((x*100) + 0.5))%10)*0.6 + 0.5);
 
    printf("\n\n[DMS]\n %i.%i'%i''\n\n",myAngle.grad,myAngle.min,myAngle.sec);
 
return myAngle;
}
округление делает вот эта штука
C++
1
static_cast<int>(x +0.5)
Добавлено через 3 минуты
Genn55, кстати ваш вариант мне больше нравится, только не знаю чем. Наверное тем что я не понимаю, что такое
C++
1
static_cast<int>(x +0.5)
а про floor() уже читал и юзал

Добавлено через 5 минут
ps. только перевод градусы в минуты и секунды функция пока, что походу не правильно делает. Сверился с онлайн калькулятором
http://planetcalc.com/1129/

но суть то была в округлении. округление верно работает
просто мне немного кажется, что не красиво такое ну и не грамотно.

Добавлено через 4 минуты
Genn55, кстати почему floor(), а не ceil()?

Добавлено через 4 минуты
Genn55,
а еще ваш код не верно округляет для числа 3.1445
C++
1
double y=floor ((3.1445) * 100 + 0.5) / 100;
Genn55
341 / 188 / 37
Регистрация: 26.12.2012
Сообщений: 658
03.06.2013, 23:27     Округление числа double до десятых, до сотых #6
floor() по нашим правилам округления 0.5 будет 1.
GBIT
 Аватар для GBIT
11 / 11 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 23:36  [ТС]     Округление числа double до десятых, до сотых #7
Цитата Сообщение от Genn55 Посмотреть сообщение
floor() по нашим правилам округления 0.5 будет 1.
C++
1
2
3
4
5
6
7
8
9
#include <iostream>
 
 int main()
{
    
 
    double y=floor (0.5);
    std::cout<<y<<std::endl;
}
выдает 0
Genn55
341 / 188 / 37
Регистрация: 26.12.2012
Сообщений: 658
03.06.2013, 23:51     Округление числа double до десятых, до сотых #8
Мнения по поводу 0,5 расходятся.Меня в школе учили (было это очень давно)0,5 округляется до 1.В других стандартах по другому.Можно использовать и ceil() будет по другому.

Добавлено через 2 минуты
Правильно

Добавлено через 2 минуты
C++
1
2
3
4
5
6
7
8
9
10
#include <iostream>
#include <math.h>
 int main()
{
 
double y;
     y=floor((0.5) + 0.5) / 1;
    std::cout<<y<<std::endl;
    return 0;
}
Все будет верно

Добавлено через 2 минуты
как меня учили
C++
1
2
3
4
5
6
7
8
9
10
#include <iostream>
#include <math.h>
 int main()
{
 
double y;
     y=floor((3.1445) * 1000 + 0.5) / 1000;
    std::cout<<y<<std::endl;
    return 0;
}
Будет 3,145

Добавлено через 7 минут
Извиняюсь!
C++
1
y=ceil((3.1445) * 100 + 0.5) / 100
дает не верный результат.Просто я им никогда не пользовался.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.06.2013, 23:57     Округление числа double до десятых, до сотых
Еще ссылки по теме:

C++ printf. Округление чисел типа double
Убрать округление double C++
Преобразовать 2 числа int в 1 число float(double) | double int1.int2 C++

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

Или воспользуйтесь поиском по форуму:
GBIT
 Аватар для GBIT
11 / 11 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 23:57  [ТС]     Округление числа double до десятых, до сотых #9
ага, усвоил теперь.
но в конечном выехал на floor()
вот такой конвертер:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
struct dms
{
    int     grad;
    int     min;
    int     sec;
};
 
dms DmsConverter(double angle)
{
    dms     myAngle;
    double  x,y;
 
    x = modf(/*angle*/3.1415,&y);
    myAngle.grad = y;
    myAngle.min = floor(x*0.6*100);
    myAngle.sec = floor((x*0.6*100-myAngle.min)*100 *0.6);
 
    printf("\n\n[DMS]\n %i.%i'%i''\n\n",myAngle.grad,myAngle.min,myAngle.sec);
 
    return myAngle;
}
все верно считает, я проверял
Yandex
Объявления
03.06.2013, 23:57     Округление числа double до десятых, до сотых
Ответ Создать тему
Опции темы

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