Solved

stream input/output:  output decimal to binary on the screen

Posted on 2004-03-23
4
240 Views
Last Modified: 2011-09-20
Hi,

I have a simple assignment where I have to convert 5 digits from an int array 'a'  to binary, oct,  dec, and  hex.
The oct, dec, hex are no problem, but I cannot figure out how to convert the decimal values to binary.  I know there is a simple way to do this without writing an algorithm, but I'm at a loss.  Besides, I'm not SUPPOSED to write an algorithm.
tried ios::binary too, but no luck.

code snippet of my output from the array is below followed by how its supposes to look
BTW: width8 is self-defined stream manipulator I wrote to format output to 8 spaces wide:

 for ( int i = 0; i < size; i++ ){
       cout << width8 <<  -->>binary convertion here? <--  << a[i];  //binary
                                                                                                
       cout << width8 << showbase << oct << a[i] << noshowbase;  //oct
       cout << width8 << dec << a[i];                                              //dec
       cout << width8 << uppercase << hex << a[i];                        //hex
       cout << endl;
       }
 cout << endl;



Table with the numbers in various bases
bin        oct      dec     hex
1010      012      10      A
10100    024      20      14
11110    036      30      1E
101000  050      40      28
110010  062      50      32
 
0
Comment
Question by:r3r
  • 2
4 Comments
 
LVL 10

Accepted Solution

by:
Sys_Prog earned 500 total points
ID: 10664225
0
 
LVL 10

Expert Comment

by:Sys_Prog
ID: 10664232
0
 

Author Comment

by:r3r
ID: 10664694
thanks all.  i appreciate it.
R
0
 
LVL 17

Expert Comment

by:rstaveley
ID: 10666072
The standard library also has bitset, which is nice for binary numbers, if you are OK with leading zeros:
--------8<--------
#include <iostream>
#include <iomanip>
#include <bitset>
#include <vector>

int main()
{
        const int size = 5;
        std::vector<int> a(size);
        for (int i = 0;i < size;++i)
                a[i] = 10*(i+1);
        for (int i = 0;i < size;++i)
                std::cout
                        << std::setw(8) << std::bitset<6>(a[i]) /* Six bit bitset */
                        << std::setw(8) << std::oct << std::showbase << a[i]
                        << std::setw(8) << std::hex << std::showbase << a[i]
                        << std::setw(8) << std::dec << std::showbase << a[i]
                        << '\n';
}
--------8<--------
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say 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

In days of old, returning something by value from a function in C++ was necessarily avoided because it would, invariably, involve one or even two copies of the object being created and potentially costly calls to a copy-constructor and destructor. A…
Templates For Beginners Or How To Encourage The Compiler To Work For You Introduction This tutorial is targeted at the reader who is, perhaps, familiar with the basics of C++ but would prefer a little slower introduction to the more ad…
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 user default arguments when defining functions. This method of defining functions will be contrasted with the non-default-argument of defining functions.

839 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