Hexa,八进制,二进制到十进制(C ++)

时间:2017-03-07 16:17:54

标签: c++ decimal

我正在尝试制定有关转化的计划。该程序应将二进制,八进制和十六进制数转换为十进制数。该程序包含一些错误,因为十进制数字是错误的。有人可以帮帮我吗? 这是代码:

#include <conio.h>
#include <iostream>
#include <windows.h>
#include <stdlib.h>
#include <math.h>

using namespace std;

int Decimal,Lenght,Pos_bit,x,base,i,n;
//Pos_bit=Exponent

char c[9];
int main()
{
    Decimale=0;
    Pos_bit=0;
    n=0;
    cout<<"Select a conversion method"<<endl; 
    cout << endl << endl;
    cout << "1)Binary-Decimal" << endl;
    cout << "2)Octal-Decimal" << endl;
    cout << "3)Hexa-Decimal" << endl;
    cin >> x;
    switch (x) 
    {
           case (1):
           base=2;
           break;
           case (2):
           base=8;
           break;
           case (3):
           base=16;
           }
    cout<<"How many digits has the number?"<<endl;
    cin>>Lenght;
    Pos_bit=Lenght; 
    for(i=0;i<Lenght;i++,Pos_bit--)
    {
    cout<<"Type-bit value"<<endl;
    cin>>c; 
    if(base==2){
        if(c[i]==48){
        n=0;}
    else if(c[i]==49){
        n=1;}
    Decimal=Decimal+n*(pow(2,Pos_bit));
    }
    else if(base==8){
    if ((c[i]>=48)&&(c[i]<=55)){    
    n=c[i]-48;}
    Decimal=Decimal+n*(pow(8,Pos_bit));
    }
    else if(base==16){
        if((c[i]>=48 && c[i]<=57)){
        n=c[i]-48;}
    else if((c[i]>=65)&&(c[i]<=70)){
        n=c[i]-55;}
    else if((c[i]>=97)&&(c[i]<=102)){
        n=c[i]-87;}
    Decimal=Decimal+n*pow(16,Pos_bit);
    }
    }

    cout<<"Decimal number is"<<Decimal<<endl;
    getch();
    system("cls");
    return 0;
    }

感谢您的帮助!

2 个答案:

答案 0 :(得分:0)

最大的问题是你处理Pos_bit的方式。你有一个错误。

假设我想从二进制转换11。 Lungh_num因此Pos_bit从2开始。您的第一个数字计算将是

Decimale=Decimale + 1 * (pow(2, 2));

答案是4.你的最终答案是6.在循环之前,设置

Pos_bit = Lungh_num - 1;

实际上,最好的办法是完全忘掉pow()的东西。而不是

 Decimale=Decimale+n*pow(16,Pos_bit);

 Decimale = Decimale * base + n;

答案 1 :(得分:0)

如果我们不关心输入清理和魔术数字以及其他编码标准问题,那么您的主要错误是:

  • 我们将位数从0计为n-1,因此该行应为:Pos_bit = Lungh_num - 1;
  • 在您使用c[i]的任何地方,您应该将其替换为c[0]。如果我没有弄错的话,你只关心输入中的第一个字符。

您更正后的代码应如下所示:

#include <conio.h>
#include <iostream>
#include <windows.h>
#include <stdlib.h>
#include <math.h>

using namespace std;

int Decimale, Lungh_num, Pos_bit, x, base, i, n;
//lungh_num=n lenght;
//Pos_bit=Exponent

char c[9];
int main()
{
    Decimale = 0;
    Pos_bit = 0;
    n = 0;
    cout << "Scegli un metodo di conversione" << endl;
    cout << endl << endl;
    cout << "1)Binario-Decimale" << endl;
    cout << "2)Ottale-Decimale" << endl;
    cout << "3)Esadecimale-Decimale" << endl;
    cin >> x;
    switch (x)
    {
    case (1):
        base = 2;
        break;
    case (2):
        base = 8;
        break;
    case (3):
        base = 16;
    }
    cout << "Quante cifre ha il numero?" << endl;
    cin >> Lungh_num;
    Pos_bit = Lungh_num - 1;
    for (i = 0; i < Lungh_num; i++, Pos_bit--)
    {
        cout << "Digita valore bit" << endl;
        cin >> c;
        if (base == 2) {
            if (c[0] == 48) {
            n = 0;
        }
        else if (c[0] == 49) {
            n = 1;
        }
        Decimale = Decimale + n*(pow(2, Pos_bit));
        }
        else if (base == 8) {
            if ((c[0] >= 48) && (c[0] <= 55)) {
                n = c[0] - 48;
            }
            Decimale = Decimale + n*(pow(8, Pos_bit));
        }
        else if (base == 16) {
            if ((c[0] >= 48 && c[0] <= 57)) {
                n = c[0] - 48;
            }
            else if ((c[0] >= 65) && (c[0] <= 70)) {
                n = c[0] - 55;
            }
            else if ((c[0] >= 97) && (c[0] <= 102)) {
                n = c[0] - 87;
            }
            Decimale = Decimale + n*pow(16, Pos_bit);
        }
    }

    cout << "Il numero decimale e'" << Decimale << endl;
    getch();
    system("cls");
    return 0;
}