Solved

decimal rounding

Posted on 1998-12-12
4
284 Views
Last Modified: 2012-05-04
What's the easiest way to round (or truncate) a double value?

example:

I have   3.21453235
I want   3.21

Thanks
0
Comment
Question by:talaskam
4 Comments
 
LVL 1

Accepted Solution

by:
MatthewL earned 50 total points
ID: 1180028
Hi talaskam;

You can shift the number the required number of decimal places, truncate it, and shift it back again.  The function round listed below does that.  It has a limitation on the size of the numbers used ( since I've cast into a long int ).

Matt

#include <iostream.h>
#include <math.h>

double round( double number, int decPlace );


void main( void )
{
      double value = 3.21453235;

      value = round( value, 2 );

      cout << value << endl;

}

double round( double number, int decPlace )
{
      long int temp;

      number *=  pow( 10, decPlace );
      temp = (long int)( number + .5 );
      number = ( double ) temp;

      number /= pow( 10, decPlace );

      return( number );
}
0
 
LVL 84

Expert Comment

by:ozo
ID: 1180029
Now try it with
value = round( -3.21453235, 2);
0
 
LVL 22

Expert Comment

by:nietod
ID: 1180030
To avoid the limitations of 32 bit integers and (I believe) to have the correct (well, most accepted) rounding for negatives, use

number *=  pow( 10, decPlace );
number = floor( number + .5 );
number /= pow( 10, decPlace );
0
 

Expert Comment

by:mmachie
ID: 1180031
iff this is for printing the value you can just use the width and precision stuff for printf.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Errors will happen. It is a fact of life for the programmer. How and when errors are detected have a great impact on quality and cost of a product. It is better to detect errors at compile time, when possible and practical. Errors that make their wa…
Introduction This article is the first in a series of articles about the C/C++ Visual Studio Express debugger.  It provides a quick start guide in using the debugger. Part 2 focuses on additional topics in breakpoints.  Lastly, Part 3 focuses on th…
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.
The viewer will learn how to clear a vector as well as how to detect empty vectors in C++.

911 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

17 Experts available now in Live!

Get 1:1 Help Now