C++에서 부동 소수점 숫자의 정밀도 설정
-
std::setprecision
을 사용하여 C++에서 부동 소수점 숫자의 정밀도 설정 -
std::floor
및std::ceil
을 사용하여 부동 소수점 숫자의 정밀도 수정 -
std::round
및std::lround
를 사용하여 부동 소수점 숫자의 정밀도 수정
이 기사에서는 C++에서 부동 소수점 숫자의 정밀도를 설정하는 방법에 대한 몇 가지 방법을 설명합니다.
std::setprecision
을 사용하여 C++에서 부동 소수점 숫자의 정밀도 설정
std::setprecision
은 입력 / 출력 스트림을 형식화하는 데 사용할 수있는 STL I/O 조작기 라이브러리의 일부입니다. setprecision
은 부동 소수점 숫자의 정밀도를 변경하며 소수점 뒤에 표시 할 숫자 자릿수를 지정하는 정수 매개 변수 만 사용합니다. 즉, 부동 소수점 숫자에 대해 암시 적으로 가정되는 기본 정밀도는 쉼표 뒤의 6 자리입니다. 그럼에도 불구하고 숫자가 너무 적고 조작자가 사용되지 않은 경우 때때로 부동 소수점이 과학적 표기법으로 표시 될 수 있습니다. 다음 예제 코드에서와 같이 이러한 숫자는 모든 유효 자릿수를 잃고 0으로 나타날 수 있습니다.
#include <iomanip>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::fixed;
using std::setprecision;
using std::vector;
int main() {
vector<double> d_vec = {123.231, 2.2343, 0.012,
26.9491092019, 113, 0.000000234};
for (auto &i : d_vec) {
cout << i << " | ";
}
cout << endl;
for (auto &i : d_vec) {
cout << setprecision(3) << i << " | ";
}
cout << endl;
return EXIT_SUCCESS;
}
출력:
123.231 | 2.2343 | 0.012 | 26.9491 | 113 | 2.34e-07 |
123.231 | 2.234 | 0.012 | 26.949 | 113.000 | 0.000 |
std::floor
및std::ceil
을 사용하여 부동 소수점 숫자의 정밀도 수정
std::floor
및std::ceil
함수는 원래 C 표준 라이브러리에서 구현 된<cmath>
헤더에서 제공됩니다. ceil
함수는 유일한 인수로 전달 된 부동 소수점보다 크거나 같은 가장 작은 정수 값을 계산합니다. 반면 floor
는 인수보다 작거나 같은 가장 큰 정수 값을 계산합니다. 이러한 함수는float
,double
및long double
유형에 대해 정의됩니다.
#include <cmath>
#include <iomanip>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::fixed;
using std::vector;
int main() {
vector<double> d_vec = {123.231, 2.2343, 0.012,
26.9491092019, 113, 0.000000234};
for (auto &i : d_vec) {
cout << i << " | ";
}
cout << endl;
for (auto &i : d_vec) {
cout << fixed << std::ceil(i) << " | ";
}
cout << endl;
for (auto &i : d_vec) {
cout << fixed << std::floor(i) << " | ";
}
cout << endl;
return EXIT_SUCCESS;
}
출력:
123.231 | 2.2343 | 0.012 | 26.9491 | 113 | 2.34e-07 |
124.000000 | 3.000000 | 1.000000 | 27.000000 | 113.000000 | 1.000000 |
123.000000 | 2.000000 | 0.000000 | 26.000000 | 113.000000 | 0.000000 |
std::round
및std::lround
를 사용하여 부동 소수점 숫자의 정밀도 수정
또는std::round
및std::round
를 사용하여 0에서 멀어지는 가장 가까운 정수 값을 계산할 수 있습니다. 이러한 함수는 페이지에서 자세히 설명하는 부동 소수점 산술 관련 오류를 발생시킬 수 있습니다.
#include <cmath>
#include <iomanip>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::fixed;
using std::vector;
int main() {
vector<double> d_vec = {123.231, 2.2343, 0.012,
26.9491092019, 113, 0.000000234};
for (auto &i : d_vec) {
cout << i << " | ";
}
cout << endl;
for (auto &i : d_vec) {
cout << fixed << std::round(i) << " | ";
}
cout << endl;
for (auto &i : d_vec) {
cout << fixed << std::lround(i) << " | ";
}
cout << endl;
return EXIT_SUCCESS;
}
출력:
123.231 | 2.2343 | 0.012 | 26.9491 | 113 | 2.34e-07 |
123.000000 | 2.000000 | 0.000000 | 27.000000 | 113.000000 | 0.000000 |
123 | 2 | 0 | 27 | 113 | 0 |
Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.
LinkedIn Facebook