将用户输入数字转换为整数向量(C ++)

时间:2018-06-15 08:36:35

标签: c++ parsing number-formatting stdvector

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

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;
     }
}

有效。但是当输入长度未知时我该怎么办?

4 个答案:

答案 0 :(得分:3)

简单地使用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-catchtry将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的解决方案

答案 1 :(得分:2)

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

答案 2 :(得分:1)

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

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

答案 3 :(得分:1)

我想保留数字,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的前面。之后,您使用/10“切断”该数字。

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