inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

7.11 최대, 최소, 평균 구하기 예제

float의 가장 작은 값

933

CJS

작성한 질문수 22

1

강의에서 1:00에서 변수 max에다가 float가 가질 수 있는 가장 작은 값을 입력하는데 FLT_MAX에다가 -를 붙이는데 FLT_MIN을 사용하지 않는 이유가 뭔가요?

또 정수형의 경우

예를들어 char형이면 char형의 최댓값은 127이고 최솟값은 -128이어서 최댓값인 127에 -를 붙여도 최솟값이 안되는데

실수의 경우는 다른가요? 그냥 최대값인 FLT_MAX에 -를 붙이면 최솟값이 되나요?

 

항상 감사합니다!!!

 

c

답변 1

1

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

실수 자료형과 정수 자료형 간의 숫자를 표현하는 방식 차이 때문에 가능한 것입니다.

실수 자료형은 부호 비트, 지수부, 그리고 가수부 라는 세 가지 부분으로 구성됩니다. (참고 - 강의 3.11 부동소수점형)
부호 비트는 값이 양수인지 음수인지를 결정하고, 지수부와 가수부는 실제 수치를 결정합니다.
이러한 방식 때문에, float 의 최대 값에 - 부호를 붙이면,
부호 비트만 변경되고 지수와 가수는 그대로 유지되므로, float 이 가질 수 있는 가장 작은 값을 나타낼 수 있습니다.

하지만, 정수형의 경우, 표현하는 방식 때문에 음수의 최대 절대값이 양수의 최대 절대값보다 1 크게 됩니다.
예를 들어, 말씀하신대로 8 비트 char 자료형의 경우, 최댓값은 127 이고 최솟값은 -128 입니다.

마지막으로, FLT_MIN0 보다 큰 가장 작은 float을 나타냅니다.
즉, 0 에 가장 가까운 양의 float 값을 나타내는 것이지, float 이 가질 수 있는 가장 작은 값을 나타내는 것이 아닙니다.
참고 링크를 첨부드립니다.

Export template 안됨

1

30

2

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

1

57

3

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

1

57

2

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

1

55

2

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

1

49

1

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

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

138

2

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

1

61

2

getchar(), putchar()

1

94

3

강의자리ㅛ

1

80

2

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

1

114

2

소스파일안에 여러 파일

1

76

2

F5와 F7의 차이

1

79

2

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

1

60

2

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

1

70

1

Step over 기능 문의

1

53

2

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

1

76

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

61

2

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

1

62

2

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

1

65

2

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

1

53

2

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

1

54

2