[출처] : http://myhome.hanafos.com/~kukdas/doc/cpp/c_use-13.html


---------- 반올림 함수 1 -----------

#include <math.h> 
double round(double x)
/* 반올림을 해주는 함수,음수일 경우 반내림을 한다. */
{
   return ((x>0) ? floor(x+.5) : ceil(x-.5));
}

(설명)

C에는 특별히 반올림을 해주는 함수가 없다.
그러나 아주 간단하게 반올림을 할 수 있는 방법이 있다.
즉, x가 양수인 경우에 floor(x+0.5) 라고 해주면
반올림이 저절로 된다.
그러나 음수에서는 반내림(-1.9 => -2.0)을 하는 것이
오히려 상식적이므로 반올림을 하는 함수를 새로 제작.
ceil()은 올림을 하는 함수이고, floor()는 내림을 하는
함수이다.
단순히 return floor(x+.5) 또는
return (double)(int)(x+.5) 라고 하면 양수일 때만
원하는 결과를 가져온다.
반드시 math.h를 include 해주어야 한다.

---------- 반올림 함수 2 -----------

#include <math.h>

double round2(double a, int b)
/* 소수점 아래자리에서도 반올림 해주는 함수 */
/* a-반올림 할 수, b-반올림할 소수점 자리  */
{
   a*=pow10(b-1);
   a=(a>0) ?  floor(a+0.5) : ceil(a-0.5);
   a*=pow10(-(b-1));
   return a;
}

(설명)

앞서의 round() 함수는 소수점 아래자리에서는
반올림할 수가 없었다.
이것을 pow10() 함수를 써서 매개변수에 소수점 정보를
추가한 것이다.
그래서 b를 그 소수점 정보로 하여 원하는 위치로
10의 배수를 곱하여, 첫째자리에서 반올림을 한후
다시 원상복귀시킨 것이다.

   ex) p=round2(3.141592, 3); 
         => p에는 3.140000 이 저장된다.
 

반응형

+ Recent posts