## 반올림 함수 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> /* 소수점 아래자리에서도 반올림 해주는 함수 */ /* a-반올림 할 수, b-반올림할 소수점 자리 */ double round2(double a, int 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 이 저장된다.