题目要求:
输入一个字符串,内有数字和非数字字符,如
a123bf456?dfdsf56181
将其中连续的数字作为一个整数,依次存放到一数组a中。例如,123放在a[0],456放在a[1]……统计共有多少个整数,并输出这些数。
#include<iostream>
#include<cctype>//用来判断一个字符是不是数字的库函数
using namespace std;
void main() {
char s[100];
cout << "请输入一个字符串:" << endl;
cin.getline(s, 90);
int a[100];
int j = 0;//添加上的数字的位置
int sum=0;//记录连续数字的大小
char *cursor;
cursor= s;//相当于游标来记录统计到哪里了
while (*cursor != '\0') {
//先判断是不是整数
if (isdigit(*cursor)) {
sum = sum * 10 + (*cursor - '0');
cursor++;
if (isdigit(*cursor) == false) {
//如果下一位不是数字就将整数添加到数组a中
a[j] = sum;
j++;
sum = 0;
}
continue;
}
cursor++;
}
cout << "字符串中包含的整数个数为:" << j << "个" << endl;
cout << "这些整数为:" << endl;
for (int k = 0; k < j; k++) {
cout << a[k] << " ";
}
}