4:15에 나오는 float round-off문제에서 든 생각입니다
384
작성한 질문수 2
float a = 0.01f;
변수 a를 이렇게 초기화 하면 실제 a에는
0.01이 아니라 0.009999999776이 담깁니다.
printf("%f", a);를 했을 때 0.010000이 나오는 이유가
0.009999999776이 소수점 일곱번째자리에서 반올림 되어서 그렇게 출력되는게 맞는가요?
답변 1
1
안녕하세요, 답변 도우미 Soobak 입니다.
말씀해주신 내용이 맞습니다. 😀
printf() 함수에서 부동 소수점 값은 기본적으로 소수점 이하 6자리까지 출력되도록 정의되어있습니다.
이는 C언어 표준에 의한 것이라고 합니다.
따라서, printf("%.8f", a) 등과 같이 %f 서식 문자열 뒤에 추가적으로 . 과 숫자를 추가하여 출력할 소수점의 자리수를 설정하지 않는다면, 기본적으로 소수점 이하 6자리까지 출력이 되며, 소수점 이하 7자리에서 반올림이 수행됩니다.
또한, 이는 강의 3.11 부동소수점형 의 13:10 부분에서 교수님께서 설명해주시듯이,
4바이트의 부동소수점은 10진수 기준으로 유효숫자(정밀도를 보장할 수 있는 숫자)가 6개라는 것과 연결지어 생각할 수 있을 것 같습니다.
질문해주셔서 감사드리고, 또 궁금한 점 있으시면 언제든지 편하게 댓글 남겨주세요! 😀화이팅!
Export template 안됨
1
45
2
완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.
1
70
3
main 함수에서 왜 int만 선언이 되는걸까요
1
63
2
8비트 2진수 변환시 왜 1을 더해야하나요?
1
62
2
혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?
1
58
1
프로토타입과 함수간의 인자 불일치
1
81
2
12.12 헤더 관련 질문
1
63
2
Visual Studio Community 2026 사용 문의
1
149
2
Q. 15:30, 부호가 있는 8비트 정수 질문
1
65
2
getchar(), putchar()
1
96
3
강의자리ㅛ
1
85
2
비주얼스튜디오코드로 공부해도 상관없나요?
1
119
2
소스파일안에 여러 파일
1
80
2
F5와 F7의 차이
1
82
2
c = TWO * (a+b); 에서 a와 b는?
1
63
2
; 세미콜론을 붙이는 기준에 문의
1
72
1
Step over 기능 문의
1
57
2
2.6 강의 따옴표 출력 규칙 문의
1
81
2
int main 함수 관련 오류 문의
1
71
2
13.4 words[0]
0
64
2
11.7 함수를 구현해 봤습니다.
1
65
2
11.6 직접 strcmp와 strncmp를 구현해 보았습니다.
1
67
2
11.6 my_strcat과 my_strncat을 구현해봤습니다.
1
57
2
11.6 fit_str함수를 구현해 봤습니다.
1
56
2





