>Java >java지도 시간 >불필요한 0을 제거하기 위해 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?

불필요한 0을 제거하기 위해 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-22 13:04:55381검색

How Can We Precisely Format Floating-Point Numbers to Eliminate Unnecessary Zeros?

부동 소수점 숫자의 정밀한 서식 지정: 불필요한 0 제거

수치 데이터를 표현할 때 정밀도와 가독성의 균형을 맞추는 것이 어려울 수 있으며, 특히 부동 소수점 숫자를 다룰 때 더욱 그렇습니다. 포인트 번호. 이러한 숫자를 인쇄할 때 문제가 발생하며, 이로 인해 후행 0이나 불필요한 소수 자릿수가 발생하는 경우가 많습니다.

문제:

다음을 포함한 모든 숫자 값을 나타내려면 double 유형을 사용하는 것이 좋습니다. 정수. 그러나 이러한 의사 정수를 double로 인쇄하면 작은 값에 대해 뒤에 0이 오는 문제가 발생합니다.

원하는 출력:

목표는 double을 깔끔하게 인쇄하는 것입니다. 형식, 실제 값의 정밀도를 유지하면서 정수 값의 후행 0을 억제합니다. doubles.

해결책:

이 상황을 효과적으로 처리하려면 double이 최대 2까지의 정수를 정확하게 나타낼 수 있다는 사실을 활용하는 사용자 정의 형식 지정 기능을 구현할 수 있습니다53. fmt(double d)라는 함수는 다음과 같이 작동합니다.

if (d == (long) d) {
    return String.format("%d", (long) d);
} else {
    return String.format("%s", d);
}

이를 사용하면 %d 형식 지정자를 활용하여 의사 정수를 정수로 인쇄할 수 있지만 실제 double은 %s를 사용하여 정밀도를 유지할 수 있습니다. 지정자.

출력 예:

사용자 정의 형식 지정 기능은 다음을 생성합니다. 출력:

232
0.18
1237875192
4.58
0
1.2345

성능 최적화:

문자열 조작을 방지함으로써 fmt 함수는 효율적인 성능을 보장합니다. 대조적으로, 0 자르기에 의존하는 솔루션은 문자열 연산으로 인해 상당한 성능 저하를 초래할 수 있습니다.

위 내용은 불필요한 0을 제거하기 위해 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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