정수 나누기가 항상 반올림되도록 하는 방법
이 글의 목적은 정수 나누기가 항상 반올림되도록 보장하는 신뢰할 수 있는 방법을 찾는 것입니다.
원래 방법 검토
원래 제안은 정수를 배정밀도 부동 소수점 숫자로 변환하고 Math.Ceiling()
함수를 사용하여 결과를 반올림하는 것이었습니다. 이 접근 방식은 효과가 있는 것처럼 보이지만 유형 변환으로 인해 불필요한 복잡성과 잠재적인 정밀도 문제가 발생할 수 있습니다.
강력한 솔루션
이 문제를 해결하기 위해 보다 포괄적이고 강력한 솔루션이 아래에 제공됩니다.
<code class="language-java">public static int DivRoundUp(int dividend, int divisor) { if (divisor == 0 || (dividend == Integer.MIN_VALUE && divisor == -1)) throw new ArithmeticException("Invalid input"); // 显式处理异常情况 int roundedTowardsZeroQuotient = dividend / divisor; boolean dividedEvenly = (dividend % divisor) == 0; if (dividedEvenly) return roundedTowardsZeroQuotient; boolean wasRoundedDown = ((divisor > 0) == (dividend > 0)); if (wasRoundedDown) return roundedTowardsZeroQuotient + 1; else return roundedTowardsZeroQuotient; }</code>
설명
이 기능은 다음을 포함하여 가능한 모든 상황을 꼼꼼하게 처리합니다.
주요 고려사항
이러한 원칙을 따르면 정수 나누기를 위한 강력하고 안정적인 반올림 코드를 개발할 수 있습니다.
위 내용은 정수 나누기가 항상 반올림되도록 보장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!