Darian Nwankwo
Darian Nwankwo

Reputation: 79

C++ manually Convert string to int?

I was trying to manually convert a string to an int, and I have had difficulties. I first check to see if the string entered is an integer. Next, I want to convert that string to an integer without using any library methods.

When I ran the code inside my loop line by line, it did what I needed it to, but when I ran it inside a loop, it spat out incorrect binary results.

==> I am going to check if the value you enter is a number.

==> Enter a number: 234

==> Input result: 1

==> Press enter to continue...

==> 11001

// Darian Nwankwo, Random Programs, August 2, 2015

#include <iostream>
#include <string>
#include <cmath>

int main(int argc, const char * argv[]) {
    std::string number = "";
    bool isNumber = false;

    std::cout << "I am going to check if the value you enter is a number." << std::endl;
    std::cout << "Enter a number: ";
    std::cin >> number;
    std::cin.ignore();

    // Iterate through variable number to check if it is a number
    for ( int i = 0 ; i < number.length() ; i++ ) {
        if ( number[i] < 48 || number[i] > 57) {
            break;
        } else {
            isNumber = true;
        }
    }

    std::cout << "Input result: " << isNumber << std::endl;

    int newNumber = 0;             
    // Iterates over the number string variable and converts value to an integer
    if (isNumber) {
        for ( int i = 0 ; i < number.length() ; i++ ) {
            // newNumber += std::pow( 10.0, number.length() )
            newNumber = std::pow(10.0, ( number.length() - ( i + 1 ) ) * ( number[i] - '0' ));
        }
    } else {
        std::cout << "Can't convert." << std::endl;
    }

    char cont;
    std::cout << "Press enter to continue..." << std::endl;
    std::cin.get(cont);
    std::cout << newNumber;

    return 0;
}

Upvotes: 0

Views: 2943

Answers (2)

Eric19960304
Eric19960304

Reputation: 1

I modified your code:

    // Darian Nwankwo, Random Programs, August 2, 2015

#include <iostream>
#include <string>
#include <cmath>

int main(int argc, const char * argv[]) {
    std::string number = "";
    bool isNumber = true;     // <-----should be default true

    std::cout << "I am going to check if the value you enter is a number." << std::endl;
    std::cout << "Enter a number: ";
    std::cin >> number;
    std::cin.ignore();
    // Iterate through variable number to check if it is a number
    for ( int i = 0 ; i < number.length() ; i++ ) {
        if ( number[i] < 48 || number[i] > 57) {
            isNumber = false;       // <--- if not number, turn isNumber to be false
            break;
        }
    }

    std::cout << "Input result: " << isNumber << std::endl;

    int newNumber = 0;             
    // Iterates over the number string variable and converts value to an integer
    if (isNumber) {
        for ( int i = 0 ; i < number.length() ; i++ ) {
            // newNumber += std::pow( 10.0, number.length() )
            newNumber = newNumber + std::pow(10.0, ( number.length() - ( i + 1 ) )) * ( number[i] - '0' );   // <--- pow() should not include (number[i] - '0') and newNumber should be cumulative
        }
    } else {
        std::cout << "Can't convert." << std::endl;
    }

    char cont;
    std::cout << "Press enter to continue..." << std::endl;
    std::cin.get(cont);
    std::cout << newNumber;

    return 0;
}

Hope it can help.

Upvotes: 0

Abhishek Mittal
Abhishek Mittal

Reputation: 366

Change your for loop to:

    for ( int i = number.length() -1 ; i >= 0 ; i-- ) {
        int power = number.length() - i -1;
        newNumber += (std::pow( 10.0,  power) * (number[i] - '0'));

and make newNumber to double.

Hope it helps !!

Upvotes: 1

Related Questions