0 / 0 / 0
Регистрация: 08.08.2015
Сообщений: 16
1

SETprecision. В чем ошибка?

28.08.2015, 13:41. Показов 9567. Ответов 10
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <iostream>
#include <iomanip>
using namespace std;
 
int main()
{
    int n;
    long double E=2.7182818284590452353602875;
    cin>>n;
    if((n>=0)&&(n<=25)){
   cout<<fixed<<setprecision(n)<<E;
    }
    return 0;
}
"Выведите в выходной файл округленное до n знаков после десятичной точки число E. Число Е, округленное до 25 знаков после десятичной точки, равно 2.7182818284590452353602875."

Если вводить 25 то должно было получиться 2.7182818284590452353602875

А у меня выходит 2.7182818284590450907955983

Почему так получается
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.08.2015, 13:41
Ответы с готовыми решениями:

setprecision()
Есть задача: Написать программу выводящую в текстовый файл таблицу значений функций exp(x) и...

setprecision() и setiosflags()
Почему чтобы напечатать число с двумя цифрами после запятой нужно использовать обе эти функции? ...

Setw и setprecision
Всем привет! Исходник: // setprecision example #include &lt;iostream&gt; // std::cout,...

Использование манипулятора setprecision
Какой вариант более правильный. Вычислить значение выражения, включающего 5 членов:...

10
7802 / 6567 / 2987
Регистрация: 14.04.2014
Сообщений: 28,712
28.08.2015, 13:45 2
Не поддерживается такая длинная мантисса. 15 цифр для double, 19 для long double при условии, что он отличается (в VS long double то же, что и double).
0
0 / 0 / 0
Регистрация: 08.08.2015
Сообщений: 16
28.08.2015, 13:48  [ТС] 3
А как же тогда поступать?
Есть ли еще типы переменых

Добавлено через 1 минуту
Цитата Сообщение от nmcf Посмотреть сообщение
Не поддерживается такая длинная мантисса. 15 цифр для double, 19 для long double при условии, что он отличается (в VS long double то же, что и double).
А как же тогда поступать?
0
7802 / 6567 / 2987
Регистрация: 14.04.2014
Сообщений: 28,712
28.08.2015, 13:50 4
Стандартных нет. Дальше идут библиотеки для длинной арифметики. Ну или ограничь n, или используй строку, если арифметические операции не нужны.
0
Неэпический
17871 / 10636 / 2054
Регистрация: 27.09.2012
Сообщений: 26,739
Записей в блоге: 1
28.08.2015, 13:50 5
Теряется точность при вычислении с double
0
0 / 0 / 0
Регистрация: 08.08.2015
Сообщений: 16
28.08.2015, 13:56  [ТС] 6
как это строку использоавть??
0
1 / 1 / 0
Регистрация: 24.08.2015
Сообщений: 18
28.08.2015, 13:58 7
помести значение в обычный массив char
0
0 / 0 / 0
Регистрация: 08.08.2015
Сообщений: 16
28.08.2015, 14:00  [ТС] 8
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
    int a;
    cin>>a;
 if(a==0)cout<<"3"; 
 if(a==1)cout<<"2.7"; 
 if(a==2)cout<<"2.72"; 
 if(a==3)cout<<"2.718"; 
 if(a==4)cout<<"2.7183"; 
 if(a==5)cout<<"2.71828"; 
 if(a==6)cout<<"2.718282"; 
 if(a==7)cout<<"2.7182818"; 
 if(a==8)cout<<"2.71828183"; 
 if(a==9)cout<<"2.718281828"; 
 if(a==10)cout<<"2.7182818285"; 
 if(a==11)cout<<"2.71828182846"; 
 if(a==12)cout<<"2.718281828459"; 
 if(a==13)cout<<"2.7182818284590"; 
 if(a==14)cout<<"2.71828182845905"; 
 if(a==15)cout<<"2.718281828459045"; 
 if(a==16)cout<<"2.7182818284590452"; 
 if(a==17)cout<<"2.71828182845904524"; 
 if(a==18)cout<<"2.718281828459045235"; 
 if(a==19)cout<<"2.7182818284590452354"; 
 if(a==20)cout<<"2.71828182845904523536"; 
 if(a==21)cout<<"2.718281828459045235360"; 
 if(a==22)cout<<"2.7182818284590452353603"; 
 if(a==23)cout<<"2.71828182845904523536029"; 
 if(a==24)cout<<"2.718281828459045235360288"; 
 if(a==25)cout<<"2.7182818284590452353602875"; 
    return 0;
}
НАшел)))
0
1 / 1 / 0
Регистрация: 24.08.2015
Сообщений: 18
28.08.2015, 14:03 9
а не легче это было сделать через цикл =)
0
0 / 0 / 0
Регистрация: 08.08.2015
Сообщений: 16
28.08.2015, 14:57  [ТС] 10
Можешь показать как?
0
1 / 1 / 0
Регистрация: 24.08.2015
Сообщений: 18
28.08.2015, 15:04 11
char mas[]="2.7182818284590452353602875";
int prec=0;
cin >> prec;
for(int i=0;i!=prec+2;i++)
cout << mas[i];

Проверки только поставь
0
28.08.2015, 15:04
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.08.2015, 15:04
Помогаю со студенческими работами здесь

Унарная операция setprecision
Здравствуйте. Манипулятор потока fixed, насколько я понял, нужен для того, чтобы вывести значение...

Манипуляторы setprecision и fixed
Как работают эти манипуляторы? Почему с fixed и без fixed выводит по-разному? #include...

Error 'setprecision' was not declared in this scope
Глупый скела снова здесь! И так, что я опять сделал не так?)) Ошибка : error 'setprecision' was...

Setprecision работает не так как хотелось бы
Как я понимаю функция setprecision определяет сколько знаков после точки должно выводиться. Но на...


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

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

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