54페이지 예제에선
float b = 314.1592e+5; 일때, b에 저장되는 값은 정규화 되어 3.141592e+07로 저장이 되잖아요.
그러고나서 섹션 5 문제5 63page에서는
float a = 123456789.0e-5f; 일때, a에 저장되는 값은 정규화 되어 1.23456789e+03으로 저장되고,
printf("소수점a = %6.1f 지수형a = %e/n" , a, a); 로 실행할 때, 소수점a = 1.2e+03이고, 지수형a = 1.234568e+03 아닌가요?
안녕하세요.
float a = 123456789.0e-5f;
printf("소수점a = %6.1f 지수형a = %e\n", a, a);
123456789.0e-5f 에 의해 지수형태로 저장된 a의 값을 원래대로 변경하면 소수점 위치를 왼쪽으로 5칸 이동한 값인
1234.56789가 됩니다.
이 값을 6.1f로 출력하면
______ 소수점을 포함하여 6자리를 확보하여 소수점 1자리를 출력해야 하므로
____.6 이 됩니다. 소수점 첫 째자리까지 출력해야 하는데, 둘째 자리에서 반올림이 되어 .6이 출력되었습니다.
나머지 4자리에 정수 부분을 출력합니다. 만일 출력할 정수 부분보다 확보된 자리수가 적으면 정수는 모두 출력됩니다.
1234.6이 출력됩니다.
%e로 출력하면
소수점 자리수가 지정되지 않으면 f나 e는 모두 기본적으로 소수점 6자리로 출력합니다.
e는 정수 부분을 1자리만 출력하므로
1.234568 이 됩니다. 역시 소수점 마지막 6자리는 7째 자리에서 반올림 된 것이고
1.234568 은 원래의 값 1234.56789에서 소수점 위치가 왼쪽으로 3자리 이동했으므로 e+03이 되어
1.234568e+03으로 출력이 되는 것입니다.
오늘도 즐거운 하루 되세요.
-
*2018-08-23 09:09:15
안녕하세요.
float a = 123456789.0e-5f;
printf("소수점a = %6.1f 지수형a = %e\n", a, a);
123456789.0e-5f 에 의해 지수형태로 저장된 a의 값을 원래대로 변경하면 소수점 위치를 왼쪽으로 5칸 이동한 값인
1234.56789가 됩니다.
이 값을 6.1f로 출력하면
______ 소수점을 포함하여 6자리를 확보하여 소수점 1자리를 출력해야 하므로
____.6 이 됩니다. 소수점 첫 째자리까지 출력해야 하는데, 둘째 자리에서 반올림이 되어 .6이 출력되었습니다.
나머지 4자리에 정수 부분을 출력합니다. 만일 출력할 정수 부분보다 확보된 자리수가 적으면 정수는 모두 출력됩니다.
1234.6이 출력됩니다.
%e로 출력하면
소수점 자리수가 지정되지 않으면 f나 e는 모두 기본적으로 소수점 6자리로 출력합니다.
e는 정수 부분을 1자리만 출력하므로
1.234568 이 됩니다. 역시 소수점 마지막 6자리는 7째 자리에서 반올림 된 것이고
1.234568 은 원래의 값 1234.56789에서 소수점 위치가 왼쪽으로 3자리 이동했으므로 e+03이 되어
1.234568e+03으로 출력이 되는 것입니다.
오늘도 즐거운 하루 되세요.