思路:利用ASCII中“0-9”,小写字母、大写字母的顺序,实现。
代码:`
#include "iostream"
#include < string>
using namespace std;
int main()
{
string s ;
cin>>s;
int len =s.length(); //.length 表示字符串的长度
int a,b,//用来循环扫描字符串
bit,//在一个字符串中,对一个外形是数字的字符,把这样的字符转化成数字,存与bit中
num;//最终存放提取出的数字
int flag=0;//判断字符串中是否有数字
cout<<"字符串中的数字有:"<<endl;
for(a=0;a<len;a++)
{
if(s[a]>='0'&&s[a]<='9')//过滤掉外形是非数字的字符
{
flag++;
b=a;
num=0;//num每次循环的初值置为0
while(b<len&&s[b]>='0'&&s[b]<='9')
{
bit=s[b]-'0';
num=num*10+bit;
b++;
}
cout<<num<<endl;
a=b;
}
}
if(flag==0)
cout<<"字符串中无数字"<<endl;
system("pause");
}`
结果: