[C/C++] 1008번: A/B
1008번: A/B 문제는 두 정수 A와 B를 입력받은 다음, A/B를 출력하는 문제이다. +, -, *를 할 수 있었다면 쉬운 문제로 보인다. 하지만 막상 문제를 풀어보면 실패를 맛 볼 수 있다. 어떤 문제가 있어서 실패를 하는지 알아 보자.
시행 착오
1
2
3
4
5
6
7
8
#include <iostream>
int main()
{
double a, b;
std::cin >> a >> b;
std::cout << a / b;
}
간단하게 생각하고 위의 코드 처럼 작성하였지만 결과는 실패 한다.
결과물을 확인 할 수 있는 IDE나 Online complier을 사용하면 소수점이 짤리는것을 확인 할 수 있다.
소수점 짤리지 않게 출력하는 방법
cin
, cout
을 사용할 경우 입력은 문제가 없지만 출력의 경우 약간 복잡하다. 두 가지를 알아야 소수점 자리를 고정하여 출력 할 수 있다.
하나는 std::fixed
, 또 하나는 std::cout.precision()
이다.
1
2
std::fixed // 소수점 아래로 고정
std::cout.precision(n); // 실수 전체 자리수 중 n자리 까지 표현
일단, precision()
에 대해 말하자면 출력 할 실수 전체 자리수를 n자리로 표현 것이다. 소수점 아래로 n자리만큼 고정하는 것이 아니다.
아래 예시를 보자.
1
2
3
4
5
6
7
8
9
#include <iostream>
int main()
{
double a = 1234.5678;
std::cout.precision(6);
std::cout << a; // 1234.567 에서 반올림 된 1234.57 이 출력 됨
}
위와 같이 실수 전체에 대한 자리수 표현이다보니 만약 오차범위를 넉넉하게 주려면 precision
의 파라미터를 큰 수로 넘겨주어야 한다.
만약 정수 부분은 신경쓰지 않고 소수점 아래로만 고정하고 싶은 경우는 어떻게 하느냐..
이럴 때 쓰는 것이 fixed
다.
fixed 는 고정 소수점 표기로 만약 fixed를 쓰면 그 다음부터 들어오는 출력들은 소수점 아래로 설정한 precision
으로 넘겨준 값 만큼 출력이 된다.
즉, 다음과 같다는 말이다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
int main()
{
double a = 3333.333333;
std::cout.precision(6);
std::cout << a << std::endl; // 3333.33 이 출력됨
std::cout << std::fixed; // 고정 소수점 표기로 전환
std::cout << a << std::endl; // 3333.333333 이 출력 됨
std::cout.unsetf(std::ios::fixed); // 고정 소수점 표기 해제
std::cout << a << std::endl; // 3333.33 이 출력됨
}
위처럼 만약에 fixed
를 해제하고 싶다면 cout.unsetf()
에 std::ios::fixed
를 넘겨주면 된다.
정답 코드
1
2
3
4
5
6
7
8
9
10
11
#include <iostream>
int main()
{
std::cout.precision(10);
std::cout << std::fixed;
double a, b;
std::cin >> a >> b;
std::cout << a / b;
}
9자리까지 출력하는 문제이므로 넉넉하게 std::cout.precision(10);
을 주었다.
Comments