将biginteger二进制字符串128位转换为数组int [4]

时间:2019-03-26 13:36:25

标签: c++ biginteger

我的方法是在int数组的每个元素中设置位。尽管该程序适用于字符串str =“ 11111 ... 111”(所有位均为1)的情况 但是,如果字符串str =“ 100 ... 000”(63个零数字)(第一位为1,其余为0)出现问题,则我的int数组为{0,0,0,1}它必须是{0,0,1,0} 请使用我的代码给我一个解决方案,如果您的想法更好,请告诉我,以便我尽快解决问题。

int arr[4]={0};
void convert(string str)
    {

        int length = str.length();
        for (int i = length - 1; i >= 0; i--)
        {
            if (str[i] == '1')
            {
                int pos = 3 - i / 32;
                int k;
                k = (length - i - 1) % 31;
                //if (i == 0)
                //{
                //pos = 2- length/32;
                //}
                arr[pos] = (1 << k) | arr[pos];
            }
        }
    }

如果字符串具有1000 ... 00(32个数字),则int数组必须为{0,0,1,0} 如果字符串具有1000 ... 00(63个0),则int数组必须为{0,1,0,0}

1 个答案:

答案 0 :(得分:0)

因此,我为自己的问题找到了解决方案。请帮助我测试我的代码,然后让我知道是否有任何测试用例出错。谢谢。

class QInt
{
private:
    int Data[4];
public:
QInt(){

    for (int i = 0; i < 4; i++)
    {
        Data[i] = 0;
    }

}

QInt QInt::StrBinToQInt(string str)
{
    QInt temp=QInt();
    str = creString128(str);
    cout << str.length() << endl;
    cout << str << endl;
    for (int i = 127; i >= 0; i--)
    {
        int pos;
        if (str[i] == '1')
        {
            pos = i / 32;
            int k = (127-i) % 32;
            if (i % 32 == 0)
            {
                pos--;
                k = 0;
            }
            if (str[0] == '1')
            {
                pos = 0;
                k = 30;
            }
            temp.Data[pos] = (1 << k) | temp.Data[pos];
        }
    }
    return temp;
}

};

string creString(int n)
{
    string temp;
    for (int i = 0; i < n; i++)
    {
        temp += '0';
    }
    return temp;
}

string creString128(string bin)
{
    string corrBin = creString(128 - bin.length());
    corrBin += bin;
    return corrBin;
}