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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 34, средняя оценка - 4.97
GBIT
12 / 12 / 1
Регистрация: 05.10.2011
Сообщений: 219
#1

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

03.06.2013, 22:34. Просмотров 5119. Ответов 8
Метки нет (Все метки)

Приветствую всех,

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

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

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

округление числа до десятых - C++
Как округлить число до целого я знаю, s=(s-floor(s)<0.5)?floor(s):ceil(v) а как округлить, скажем, число 3.4643 до 3.5 ?

Округление Double - C++
Использую Double, возникают при тонких расчетах проблемы с округлением. Какие есть стандартные способы решения? :)

Округление double - C++
Короче ввожу число 1.05 в Debug показывает его, как 1.004999999999999999995663191310058 вот как эту чушь убрать, у меня задача из-за...

Убрать округление double - C++
Доброго времени суток! Недавно начав самостоятельно изучать С++, я пыталась выполнить лабораторную работу по созданию программы для...

Округление Long double. - C++
Нужно округлить число типа long double в меньшую сторону т.е. просто обнулить всю дробную часть, но при этом надо сохранить эту самую...

Форматирование вывода и округление double - C++
Доброго времени суток. Я много подобных тем полистал. Но не нашел ответа. Мне нужно написать функцию, которая бы получала double число,...

8
ViktorKozlov
133 / 125 / 2
Регистрация: 13.12.2012
Сообщений: 293
03.06.2013, 22:46 #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, округлить до целого и потом опять разделить и привести к вещественному
0
gray_fox
What a waste!
1522 / 1227 / 70
Регистрация: 21.04.2012
Сообщений: 2,565
Завершенные тесты: 3
03.06.2013, 22:52 #3
GBIT, во-первых, сама по себе погрешность в представлении числа с плавающей точкой почти всегда будет, поиск по сайту выдаёт такое, например: http://www.cyberforum.ru/blogs/18334/blog507.html .
0
Genn55
374 / 221 / 41
Регистрация: 26.12.2012
Сообщений: 725
03.06.2013, 23:01 #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;
}
0
GBIT
12 / 12 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 23:27  [ТС] #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;
0
Genn55
374 / 221 / 41
Регистрация: 26.12.2012
Сообщений: 725
03.06.2013, 23:27 #6
floor() по нашим правилам округления 0.5 будет 1.
0
GBIT
12 / 12 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 23:36  [ТС] #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
0
Genn55
374 / 221 / 41
Регистрация: 26.12.2012
Сообщений: 725
03.06.2013, 23:51 #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
дает не верный результат.Просто я им никогда не пользовался.
1
GBIT
12 / 12 / 1
Регистрация: 05.10.2011
Сообщений: 219
03.06.2013, 23:57  [ТС] #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;
}
все верно считает, я проверял
0
03.06.2013, 23:57
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.06.2013, 23:57
Привет! Вот еще темы с ответами:

double округление с точность до N знаков - C++
Добрый день, помогите пожалуста какую надо использовать функцию чтобы была возможность округлить значение числа double с точностью до N...

printf. Округление чисел типа double - C++
Пытаюсь писать программу для округления чисел типа double. // okruglenie double.cpp: определяет точку входа для консольного...

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

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


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

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

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