C에서 pow(10,5)가 9,999인 이유는 무엇입니까?
C에서 거듭제곱 연산을 계산하기 위해 pow 함수를 호출할 때 , 반환 값은 잠재적으로 부동 소수점 정밀도를 가질 수 있습니다. 그러나 어떤 경우에는 정수 변수에 할당하면 결과가 잘릴 수 있습니다.
제공된 예에서:
const int sections = 10; for(int t= 0; t < 5; t++){ int i = pow(sections, 5- t -1); cout << i << endl; }
pow(sections, 5- t - 1) 정수 섹션과 정수 빼기를 사용하면 정수 값이 생성됩니다. 이러한 값을 사용하여 거듭제곱을 계산하면 결과는 소수 부분이 있는 부동 소수점 값이 될 수 있습니다.
이 부동 소수점 값을 정수 변수 i에 할당하면 잘림이 발생합니다. 예를 들어, pow(sections, 5- t -1)가 9999.9999로 평가되면 소수 부분은 삭제되어 i = 9999가 됩니다.
이 문제를 방지하려면 pow 함수를 직접 사용할 수 있습니다. 출력 문 내에서:
for(int t = 0; t < 5; t++){ cout << pow(sections,5-t-1) << endl; }
이 경우 결과는 pow(sections,5-t-1)은 중간 정수 변수 없이 직접 인쇄되므로 올바른 값이 표시됩니다.
위 내용은 C에서 `pow(10,5)`가 때때로 10000 대신 9999를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!