>백엔드 개발 >C++ >C에서 `pow(5, 2)`가 24를 반환하는 이유: 데이터 형식 문제?

C에서 `pow(5, 2)`가 24를 반환하는 이유: 데이터 형식 문제?

Barbara Streisand
Barbara Streisand원래의
2024-12-06 12:03:12567검색

Why Does `pow(5, 2)` Return 24 in C  : A Data Type Issue?

pow(5, 2)가 24를 반환하는 이유: 데이터 유형 및 반올림의 문제

제공된 C 프로그램에서 pow( ) 함수는 숫자의 거듭제곱을 계산하는 데 사용됩니다. 그러나 pow(5, 2)가 실행되면 프로그램은 예기치 않게 올바른 결과인 25 대신 24를 반환합니다. 이로 인해 프로그래머는 함수가 오작동하는 것처럼 보이는 이유를 궁금해할 수 있습니다.

이 문제는 pow() 함수 내의 데이터 유형 처리에 있습니다. 기본적으로 pow()는 소수 값을 보유할 수 있는 배정밀도 부동 소수점 숫자를 반환합니다. 그러나 프로그램은 이 double을 정수 변수에 할당하여 효과적으로 소수 부분을 자릅니다. 5^2의 경우 실제 결과는 24.99997 또는 유사하지만 잘림으로 인해 24로 반올림됩니다.

이 문제를 해결하고 올바른 정수 결과를 얻으려면 pow를 명시적으로 반올림해야 합니다. () 값을 가장 가까운 정수로 변환합니다. 이는 정수 변수에 할당하기 전에 결과에 0.5를 추가하여 달성할 수 있습니다. 다음 코드 조각은 수정 내용을 보여줍니다.

int answer;
answer = pow(number1, number2) + 0.5;

0.5를 더함으로써 double을 가장 가까운 정수로 효과적으로 반올림하여 5^2의 결과가 예상대로 25가 되도록 합니다.

이 반올림 기술은 거듭제곱 계산 결과가 정수로 보장되는 경우에만 적합하다는 점에 유의하는 것이 중요합니다. 결과가 정수가 아닐 수 있는 상황(예: 제곱근)에서는 분수 값을 보존하기 위해 pow() 결과를 double 또는 float 변수에 할당하는 것이 좋습니다.

위 내용은 C에서 `pow(5, 2)`가 24를 반환하는 이유: 데이터 형식 문제?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.