如何将数字转换为整数向量?

How to convert numbers into vector of integers?

我希望我的程序要求用户输入任何数字,然后将其存储到 std::vector 中,其中每个数字都分配给一个单独的向量索引:

input: 142

output vector: [1, 4, 2]

我试过这个:

int main()
{
     std::vector<int> v;
     int number;
     cin >> number;
     for(unsigned int i = 100; i > 0; i/=10)
     {
         v.push_back(number/i);
         number -= (number/i)*i;
     }

     for(size_t i = 0; i < v.size(); ++i)
     {
         std::cout<<v[i]<<std::endl;
     }
}

有效。但是输入长度未知怎么办?

更改 for 初始化 unsigned int i = number 而不是 unsigned int i = 100。重写的 for 语句将是:

for(unsigned int i = number; i > 0; i/=10)

简单地使用 std::string 并将每个 char(实际上是整数)的字符串转换为整数,如下所示: SEE LIVE HERE

#include <iostream>
#include <vector>
#include <string>

int main()
{
    std::vector<int> v;
    std::string number = "123456789987654321";
    for(auto& Integer: number)
      v.emplace_back(static_cast<int>(Integer - '0'));

    for(const auto& it: v) std::cout << it << " ";
}

输出:

1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 

如果输入了不需要的字符/用户输入(例如一些负数甚至这个:+-1234567),您可以使用 try-catch 进行操作。 try 将 char 转换为 int,否则跳过 catch 块,如下所示。 SEE LIVE HERE

#include <iostream>
#include <vector>
#include <string>
#include <exception>
int main()
{
    std::vector<int> v;
    std::string number = "+-1234567";
    for(auto& Integer: number)
    {
        std::string Char(1, Integer); // convert to string
        try         {   v.emplace_back(std::stoi(Char));        }
        catch(...)  {   continue; }     // any case of exceptions

        /* or using much simpler std::isdigit from <cctype>
           by which conversion to std::string and try-catch can be avoided.

        if(std::isdigit(Integer))
            v.emplace_back(static_cast<int>(Integer - '0'));
        */
    }
    for(const auto& it: v) std::cout << it << " ";
}

输出:

1 2 3 4 5 6 7 

Edte:按照@Aconcagua 的建议,将解决方案包含在 std::isdigit

我想保留数字,std::deque 是一个选项,您可以执行以下操作:

int main()
{
    std::deque<int> v;
    int number;
    cin >> number;
    while(number != 0)
    {
      v.push_front(number%10);
      number = number/10;
    }
    for(size_t i = 0; i < v.size(); ++i)
    {
      std::cout<<v[i]<<std::endl;
    }
    return 0;
}

使用取模运算符,您只需取最后一位并将其插入 deque 的前面。之后你 "cut off" 那个数字 /10.

我使用了双端队列,因为you can't push front with vectors

while(number) {
  v.push_back(number%10);
  number /= 10;
}
std::reverse(v.begin(), v.end());