inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3.12 부동소수점형의 한계

3.11 강의에 대한 질문 드립니다.

445

junghoyoung8

작성한 질문수 9

0

float f 가 123.456001 가 궁금해서 질문을 보는 중 3.12 강의를 보면 된다고 하셨는데 제가 이해하기로는 유효숫자가 6개 이기 때문에 그 이후의 값은 정확하게 출력되지 않아서 123.456000이 아닌 123.456001이 출력된것이라 이해해도 될까요?

c

답변 3

7

정진호

부동소수점 형태로 저장하면 

float로 저장하는 경우 4바이트 겠죠?

근데 컴퓨터에 저장될때 2진 소수로 바뀌죠? 총 32 비트겠죠?

그럼 1비트는 sign에쓰고 8비트는 지수에 쓰고 나머지 23비트를 가수에쓰겠죠?

23비트를 쓴단 말은 가수 첫 비트가 2^-1 부터 시작하니까 2^-23 까지 쓴단 말이겠죠?

그럼 오차는 어디서부터 발생할까요?

2^-24번째 비트부터 생겨나겠죠?

그럼 '최대'오차가 얼마일까요? 2^-24 X 1 + 2^-25 X 1 + 2^-26 X 1 + ... 이거겠죠?

이거 수능공부할때 많이 봤죠? 무한등비급수의 합이죠?

다 더하면 얼마에요? 2^-23 이죠?

2^-23 은 10진수로 0.0000001192 죠?

그래서 float의 정밀도가 7자리입니다(소수점이하 6자리)

쭉 따라 읽으시면 이해가 되실겁니다 :)

0

junghoyoung8

감사합니다.

1

안소

네 맞습니다. 정밀도가 소수점 6자리까지라 7자리 부터의 값은 의미가 없긴하지만 반올림되어 6번째 자리에 반영이 됩니다. 

0

junghoyoung8

답변 감사합니다.

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

47

3

main 함수에서 왜 int만 선언이 되는걸까요

1

52

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

53

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

46

1

프로토타입과 함수간의 인자 불일치

1

72

2

12.12 헤더 관련 질문

1

59

2

Visual Studio Community 2026 사용 문의

1

134

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

59

2

getchar(), putchar()

1

92

3

강의자리ㅛ

1

78

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

112

2

소스파일안에 여러 파일

1

74

2

F5와 F7의 차이

1

75

2

c = TWO * (a+b); 에서 a와 b는?

1

58

2

; 세미콜론을 붙이는 기준에 문의

1

68

1

Step over 기능 문의

1

52

2

2.6 강의 따옴표 출력 규칙 문의

1

74

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

60

2

11.7 함수를 구현해 봤습니다.

1

62

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

64

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

53

2

11.6 fit_str함수를 구현해 봤습니다.

1

53

2

11.5 코드 구현

1

67

2