Solved

Restricting Digits

Posted on 1998-07-31
16
366 Views
Last Modified: 2010-04-02
How do I restrict output digits? For Example if
h is a float having value = 2.546709 and I want to output
it using cprintf, like cprintf (" blah %f", h); such that
only two digits show up on the screen.
0
Comment
Question by:varun071898
  • 9
  • 3
  • 3
  • +1
16 Comments
 
LVL 22

Accepted Solution

by:
nietod earned 50 total points
Comment Utility
you can use the precision() function.
0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
Like

cout.precision(3) ;

You can also use a stream manipulator like

cout << setprecision(3)  << somefloatingpointnumber << setprecision(6);
0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
Note that there are two interpretations to this precision.  If the stream is in fixed or scientific format the precison is the number of decimal digits to be displayed.  If the stream is in the automatic format, the precision is the total number of digits to be displayed.  it sounds like you want the fixed or scientific format, but I can't be sure.
0
 
LVL 3

Author Comment

by:varun071898
Comment Utility
I am using a very old version of C++. What I want is a operator like cprintf ("blah %f", h) I have used it before and have forgotten, it was something like cprintf ("blah %f2", h) something like that. I want that answer.

ps. Precision is not available.
0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
precision is for the stream output.  And you clearly stated you wanted printf() output.  Well you get what you pay for.  Bad answers at a good price.

I have to look up the printf() stuff.  It has been a while.  
0
 
LVL 1

Expert Comment

by:fkurucz
Comment Utility
to show h with 10 digits (leading spaces) and 2 decimals use
    cprintf("blah %10.2f", h)
numbers not fitting in the format (eg. "%2f",100 -> 100) will be printed normal.

0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
From VC's help I found
*********************************************
Format Specification Fields: printf and wprintf Functions

A format specification, which consists of optional and required fields, has the following form:

%[flags] [width] [.precision] [{h | l | I64 | L}]type

Each field of the format specification is a single character or a number signifying a particular format option. The simplest format specification contains only the percent sign and a type character (for example, %s). If a percent sign is followed by a character that has no meaning as a format field, the character is copied to stdout. For example, to print a percent-sign character, use %%.

The optional fields, which appear before the type character, control other aspects of the formatting, as follows:

type Required character that determines whether the associated argument is interpreted as a character, a string, or a number (see Table R.3).

flags Optional character or characters that control justification of output and printing of signs, blanks, decimal points, and octal and hexadecimal prefixes (see Table R.4). More than one flag can appear in a format specification.

width Optional number that specifies the minimum number of characters output. (See printf Width Specification.)

precision Optional number that specifies the maximum number of characters printed for all or part of the output field, or the minimum number of digits printed for integer values (see Table R.5).

h | l | I64 | L Optional prefixes to type-that specify the size of argument (see Table R.6).
*****************************
Table R.5 How Precision Values Affect Type





Type



Meaning



Default





c, C



The precision has no effect.



Character is printed.



d, i, u, o, x, X



The precision specifies the minimum number of digits to be printed. If the number of digits in the argument is less than precision, the output value is padded on the left with zeros. The value is not truncated when the number of digits exceeds precision.



Default precision is 1.



e, E



The precision specifies the number of digits to be printed after the decimal point. The last printed digit is rounded.



Default precision is 6; if precision is 0 or the period (.) appears without a number following it, no decimal point is printed.



f



The precision value specifies the number of digits after the decimal point. If a decimal point appears, at least one digit appears before it. The value is rounded to the appropriate number of digits.



Default precision is 6; if precision is 0, or if the period (.) appears without a number following it, no decimal point is printed.



g, G



The precision specifies the maximum number of significant digits printed.



Six significant digits are printed, with any trailing zeros truncated.



s, S

The precision specifies the maximum number of characters to be printed. Characters in excess of precision are not printed.

Characters are printed until a null character is encountered.
*****************************************

0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
Thus you should need

cprintf (" blah %0.2f", h)

to get 2 decimals
0
Threat Intelligence Starter Resources

Integrating threat intelligence can be challenging, and not all companies are ready. These resources can help you build awareness and prepare for defense.

 
LVL 11

Expert Comment

by:alexo
Comment Utility
Now who sounds like a textbook?
0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
hey, at least I provide a reference.  you just paste it without a word.  That's plagurism (or something like that, but spelled differently.)
0
 
LVL 11

Expert Comment

by:alexo
Comment Utility
>> That's plagurism
The plagiarism of a guru?
0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
Great, my English is being corrected by someone who speaks it as a third language.
0
 
LVL 11

Expert Comment

by:alexo
Comment Utility
et list yor ansers ar korekt ;-)
0
 
LVL 3

Author Comment

by:varun071898
Comment Utility
Hi Nietod,
I will be increasing the points to 50 and give you A: Excellent!
but please answer one more question. How do I want to have a floating point number to be changed into a character type. For ex:
float h=2.2556632
then char ch = 2.25. How do I do this. You can tell me how to do this or give the code. I want this urgently. Thanks

0
 
LVL 22

Expert Comment

by:nietod
Comment Utility
I think what you mean is you want to convert the floating point number to a character string that expresses the floating point number, like convert 2.25 to the 4 character string (plus NULL terminator) "2.25"  Is that right?  If so, you can use the sprintf() function.  There is a lot of things that can be done with the sprintf() function.  (More than I can explain here, so you need to look it up.)  But for your purposes you would do

char NumStr[5];
float h = 2.2556632;

sprintf(NumStr,"%0.2f",h);

read about sprintf() (and printf()) and let me know if you have questions.
0
 
LVL 3

Author Comment

by:varun071898
Comment Utility
Thanks nietod. As promised I have increased the points to 50 and given you A:Excellent
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

Suggested Solutions

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 viewer will learn how to clear a vector as well as how to detect empty vectors in C++.
The viewer will be introduced to the member functions push_back and pop_back of the vector class. The video will teach the difference between the two as well as how to use each one along with its functionality.

771 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

11 Experts available now in Live!

Get 1:1 Help Now