2.5부동소수점수(29분:43초) isnan 함수
안녕하세요. 아래의 코드에서 isnan(posinf)는 왜 1이 나오고, isnan(neginf)는 왜 0이 나오는 지 모르겠습니다.
posinf는 양의 무한대로 발산하고, neginf는 음의 무한대로 발산하는 것 아닌가요? 왜 둘의 결괏값이 다른 건지 이해가 가지 않는데, 자세한 설명해주시면 정말 감사하겠습니다.
#include <iostream>
#include <iomanip>
#include <limits>
#include <cmath>
using namespace std;
int main()
{
double zero = 0.0;
double posinf = 5.0 / zero;
double neginf = - 5.0 / zero;
cout << std::isnan(posinf) << endl;
cout << std::isnan(neginf) << endl;
}
답변 1
3
안녕하세요, 답변 도우미 Soobak 입니다.
NaN은 부동 소수점 연산에서 수학적으로 정의할 수 없는 결과를 나타낼 때 사용되는 특수한 값입니다.
대표적인 예시로 다음과 같은 연산이NaN을 반환합니다.0 / 0:0을0으로 나누는 연산은 결과가 모호하므로NaN으로 처리됩니다.무한대 - 무한대: 두 무한대의 차이는 정의되지 않아NaN으로 처리됩니다.sqrt(-1)실수 범위에서 음수의 제곱근은 정의되지 않으므로NaN으로 처리됩니다.무한대 * 0: 무한대와0의 곱은 얼마인지 정의할 수 없으므로NaN으로 처리됩니다.
하지만,
INF,-INF는NaN이 아닙니다.양수를
0으로 나누면+INF, 음수를0으로 나누면-INF가 됩니다.
: 따라서, 질문자님의 코드에서
cout << std::isnan(posinf) << endl;
cout << std::isnan(neginf) << endl;의 출력값은 모두 0 이 되어야 합니다.
실제로 제가 컴파일 후 실행한 결과 출력 사진을 첨부드립니다.
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
double zero = 0.0;
double posinf = 5.0 / zero;
double neginf = -5.0 / zero;
cout << "isnan posinf : " << isnan(posinf) << "\n";
cout << "isnan neginf : " << isnan(neginf) << "\n";
return 0;
}
또한, 관련 문서의 링크도 첨부드리며, 해당 링크의 예시 카테고리에서도 isnan(Inf)의 결과 값에 대해서도 다루고 있으니, 참고해보시면 좋을 것 같습니다.
강의자료는 어디서 받을 수 있죠?
1
22
2
교재 있나요?
1
140
2
11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)
1
93
3
using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다
1
103
2
cstr직접구현
0
117
3
BubbleSort
1
79
2
숙제 마지막 부분
1
80
2
강의와 똑같이 진행했는데 링킹 에러가 발생합니다.
1
96
2
수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??
1
165
2
공변반환형 관련 문의 드립니다.
1
92
2
170강 유니크 포인터에대해 질문있습니다
1
82
1
섹션 5 퀴즈의 답이 이상합니다
1
85
2
이중포인터와 배열이 이해가 안됩니다.
1
159
2
5분 17~5분 34초 객체 잘림 질문
1
80
1
Resource.h 코드 알려주세요
1
73
1
char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다
1
95
2
화면좌측 숫자 보이기
1
116
1
화면 좌측 숫자 보이기
0
68
1
처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??
1
139
3
46강 string 버퍼 질문입니다
1
82
2
프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.
1
125
2
[] 범위 검사시 assert 사용 관련 질문
1
92
2
Lecture 클래스 멤버변수 명명 관련
0
93
2
프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요
0
75
1






