将字符串整数转换为int的最简单方法

时间:2012-11-28 13:32:52

标签: c++

我有一个很长的数字,有数百个数字,我已经存储在一个字符串中。 现在,我想把它读成一个整数/长一位数。

long int strtol ( const char * str, char ** endptr, int base ); 采用结束指针,但似乎我没有设置正确,因为它试图读取所有数字,因此返回LONG_MAX

char str[]=
"70172427121883998797908792274921901699720888093776\
65727333001053367881220235421809751254540594752243\
52584907711670556013604839586446706324415722155397\
53697817977846174064955149290862569321978468622482\
83972241375657056057490261407972968652414535100474\
82166370484403199890008895243450658541227588666881\
16427171479924442928230863465674813919123162824586";

char *pEnd; //set pEnd to str[1]'s address how???
long num = strtol(str, &pEnd,  10);
cout << num << endl; //LONG_MAX

我想到了将其复制到新的字符数组,然后应用strtol的解决方案,但这似乎不是最好的方法。

那么最简单/最好的方法是什么?

5 个答案:

答案 0 :(得分:6)

如果您想阅读一个数字,您只需使用:

int digit = str[digitIndex] - '0';

无论实现使用的字符集如何,这都有效,因为标准保证数字'0' - '9'将由连续值表示。

endptr的{​​{1}}参数不符合您的想法:它用于返回转换停止的位置,而不是告诉函数停止的位置。

如果要转换strtol的多位子字符串,则只能将所需的数字复制到新字符串,如下所示:

str

然后使用one of the methods here将其转换为整数。

答案 1 :(得分:4)

将单个数字转换为其int表示很容易,例如,做

int i = str[0] - '0'; 

第一个数字。所以你只需要创建一个整数数组,遍历字符串并转换每个数字,将结果存储在整数数组中。

答案 2 :(得分:1)

结束指针是来自该strtol的输出。它告诉它停止阅读的地方,而不是相反。

如果您想阅读个别数字,请执行以下操作:

digit = str[0] - '0';

答案 3 :(得分:1)

如果基数为10,LENGTH是字符串Length,请执行:

#include <string.h>
#include <stdio.h>
#include <stdlib.h>

/*Prototype*/
long int intpow( int base, int exp);

int main(void)
{
    long int result = 0;
    int i, j = 0;
    char str[] = /* blah blah*/

    for( i = LENGHT - 1; i >= 0; i--){
        /* -48 because ASCII code. */
        result +=  ( str[ i ] - 48 ) * intpow( 10, j );
        j++;
    }
}

/* Recursive integer power function*/
long int intpow( int base, int exp)
{
    if( exp == 0)
      return 1;

    else
      return base * intpow( base, exp - 1);
}

答案 4 :(得分:1)

如果你想要转换其中一个数字而不是全部数字,请使用std :: transform:

size_t N = sizeof(str) -1 ; //or strlen(str) if str is a pointer, not an array
std::vector<int> theInts(N); 
std::transform(str, str+N, begin(theInts), [](char* pc){ return *pc -'0'; });
相关问题