基本思想:从字符串的0号位置开始寻找数字,开始设i=0,j=0。
先找第一个数字,i不断后移,遇到数字,则j=i,j为数字的最高位,i继续后移直到字符不是数字位置;
用len记录这个数字的位数;
通过string.substr()获取该子串(数字);
通过字符串流操作转换为整数型即可。
字符串其余数字重复以上操作即可。
若有更简便的方法,请大家不吝赐教
#include<iostream>
#include<vector>
#include<string>
#include<sstream>
using namespace std;
int main()
{
vector <int> a;
string s;
cin >> s;
int len_s = s.size();
int i=0, j=0;
while (i < len_s)
{
if (s[i] >= '0'&& s[i] <= '9')
{
j = i;
int len = 0;
while (s[i] >= '0'&& s[i] <= '9')
{
i++;
len++;
}
string s0 = s.substr(j, len);//获取子串
int num=0;//数字字符串转换为整型数字
stringstream s1(s0);
s1 >> num;
a.push_back(num);
}
else
{
i++;
}
}
system("pause");
return 0;
}