C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[63981] 저도 double 형으로 받아서 해봤는데 정상이었어요
조필형 [] 2154 읽음    2011-03-23 13:52
로케님이 하신것과 동일하게 정상이었다는...

어차피 실수형 상수의 default type은 double이니깐 /1000.0에서

double형 계산이 일어날텐데 절단오차가 발생한다는 것도 이상하구요. 엉엉

locke 님이 쓰신 글 :
: float f = 1000 * dif / 1000.0;
:
: x = int(f);
:
: 이렇게 해주니 정상적으로 나오는데..
:
: 결국 말씀하신 문제의 원인은 정확히 모르겠다는..typecast 문제인지..
:
: -locke
:
: 조필형 님이 쓰신 글 :
: : int max = 1000;
: : int dif = max - 998;
: :
: : x = int(1000 * dif / 1000.0);
: :
: : 을 계산하면 2가 나와야 하는데 1이 나오네요.
: :
: : 첨에 999를 빼면 0이 나오고
: : 997, 996까지 이상동작 보이다가
: : 995서부터 정상적인 계산이 됩니다.
: :
: : 혹시나 해서 Dev C++ 컴파일러로 동일한 코드 돌려봤는데 거기선 괜찮더군요.
: :
: : 뭔가 소숫점 짤림이 발생하는 걸까요?

+ -

관련 글 리스트
63978 빌더6 컴파일러 오류일까요? 조필형 2298 2011/03/23
63987     Re:빌더6 컴파일러 오류일까요? 박우성 2181 2011/03/24
63991         답변 감사드립니다.(내용없음) 조필형 1902 2011/03/25
63983     Re:빌더6 컴파일러 오류일까요? dd 2055 2011/03/23
63980     Re:빌더6 컴파일러 오류일까요? locke 2089 2011/03/23
63981         저도 double 형으로 받아서 해봤는데 정상이었어요 조필형 2154 2011/03/23
63979     나눗셈에 절단 오차일거 같긴한데 왜 1000에서만 발생할까요. 조필형 2204 2011/03/23
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.