inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

3.12 부동소수점형의 한계

4:15에 나오는 float round-off문제에서 든 생각입니다

384

황진석

작성한 질문수 2

1

float a = 0.01f;
변수 a를 이렇게 초기화 하면 실제 a에는

0.01이 아니라 0.009999999776이 담깁니다.
printf("%f", a);를 했을 때 0.010000이 나오는 이유가
0.009999999776이 소수점 일곱번째자리에서 반올림 되어서 그렇게 출력되는게 맞는가요?

c

답변 1

1

Soobak

안녕하세요, 답변 도우미 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