1

我需要将 s 的一部分转换为vectors 。 如果我有charint

std::vector<char> // which contains something like asdf1234dsdsd  

我想从第 4 到第 7 个位置获取字符并将其转换为 int。
位置总是已知的。

我如何以最快的方式做到这一点?

我尝试使用全局副本并得到一个奇怪的答案。我得到了 48 而不是 2。

4

6 回答 6

3

This is fairly flexible, although it doesn't check for overflow or anything fancy like that:

#include <algorithm>

int base10_digits(int a, char b) {
    return 10 * a + (b - '0');
}

int result = std::accumulate(myvec.begin()+4, myvec.begin()+8, 0, base10_digits);
于 2012-06-28T08:43:09.410 回答
3

如果位置是已知的,你可以这样做

int x = (c[4] - '0') * 1000 + (c[5] - '0') * 100 + (c[6] - '0') * 10 + c[7] - '0';
于 2012-06-28T08:22:00.507 回答
2

复制不起作用的原因可能是因为字节序,假设第一个char是最重要的:

int x = (int(c[4]) << 24) + (int(c[5]) << 16) + (int(c[6]) << 8) + c[7]
于 2012-06-28T08:16:12.273 回答
1

1.获取开始和结束(结束后一个)索引的地址。

2.从中构造一个std::string。

3.将其输入到 std::istringstream。

4.从字符串流中提取整数到一个变量中。

(这可能是个坏主意!)

于 2012-06-28T08:11:37.923 回答
0

尝试这个:

#include <iostream>
#include <vector>
#include <math.h>

using namespace std;

int vtoi(vector<char> vec, int beg, int end) // vector to int
{
  int ret = 0;
  int mult = pow(10 , (end-beg));

  for(int i = beg; i <= end; i++) {
    ret += (vec[i] - '0') * mult;
    mult /= 10;
  }
  return ret;
}

#define pb push_back

int main() {
  vector<char> vec;
  vec.pb('1');
  vec.pb('0');
  vec.pb('3');
  vec.pb('4');

  cout << vtoi(vec, 0, 3) << "\n";

  return 0;
}
于 2012-06-28T16:37:20.323 回答
-1
long res = 0;

for(int i=0; i<vec.size(); i++)
{
     res += vec[i] * pow (2, 8*(vec.size() - i - 1)); // 8 means number of bits in byte
}
于 2017-03-30T09:16:09.420 回答