나눗셈 결과 혼란: 왜 3/5가 Double로 저장되었음에도 불구하고 0이 나오나요?
나눗셈(/)을 수행하려고 할 때 C에서는 관련된 데이터 유형을 이해하는 것이 중요합니다. 정수 나누기(int 유형)는 정수 나누기로 이어지며, 이로 인해 소수 부분이 삭제됩니다. 그러나 이는 복식을 처리할 때 예상치 못한 결과를 초래할 수 있습니다.
예:
다음 코드를 고려하세요.
#include <iostream> int main() { double f = 3 / 5; std::cout << f; return 0; }
예상치 못한 출력:
많은 사람들이 놀랍게도 이 코드는 예상되는 0.6 대신 0을 인쇄합니다.
설명:
3과 5가 모두 정수이기 때문에 나누기 연산자(/)는 정수 나누기를 수행합니다. 이를 수정하려면 피연산자 하나가 실수인지 확인하세요. 이는 수정된 버전에서 볼 수 있듯이 소수점을 추가하여 달성할 수 있습니다.
double f = 3.0 / 5;
이 수정으로 인해 컴파일러는 부동 소수점 나누기를 수행하게 되며 결과는 0.6이 됩니다.
결론:
double로 나눗셈을 수행할 때는 관련된 데이터 유형을 고려하는 것이 중요합니다. 부동 소수점 피연산자를 사용하면 결과의 소수 부분이 유지되어 원하는 결과를 얻을 수 있습니다.
위 내용은 Double을 사용할 때 C의 정수 나누기가 예기치 않은 0 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!