Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

decimal rounding

Posted on 1998-12-12
4
Medium Priority
?
294 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 100 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 85

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

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

Article by: SunnyDark
This article's goal is to present you with an easy to use XML wrapper for C++ and also present some interesting techniques that you might use with MS C++. The reason I built this class is to ease the pain of using XML files with C++, since there is…
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 goal of the video will be to teach the user the difference and consequence of passing data by value vs passing data by reference in C++. An example of passing data by value as well as an example of passing data by reference will be be given. Bot…
The viewer will learn how to clear a vector as well as how to detect empty vectors in C++.
Suggested Courses

581 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