Description
ds自信熟悉了输入输出格式,有一天,Mr.Han给他出了个难题,怎么读入一行整数放到数组?ds愣了一下,一般是给定输入整数的数目,然后再读入到数组,可是一行整数里面不知道有多少个整数呢?为了降低难度,Mr.Han保证所有整数非负,要求ds回答有多少个整数?
Input
输入正整数T,表示T组测试数据
每组一行整数,整数以空格隔开,首尾没有空格,长度不超过10000
Output
整数的个数,独立一行
Sample Input
2
1 23 456 7890
21 45 6142
Sample Output
4
3
Hint
字符串的长度不超过200,字符串一定只包含一个整数,整数的数值不超过230,m<=100。
思路:
刚好打开学校oj想着做道题吧,就随便点开了一道题目,就是这道题;
我一开始看到这个题目简单的以为将字符串使用strtok分开再进行计数就可以了,再不济也可以使用if来判断字符串中有几个空格,最后再把个数加一就完事.但是我发现竟然WA了,赶紧仔细看了一下题目,竟然是找出有几个整数,但没说是全部用空格分开,也就是说可能出现1232 23123 2321321 231这样的情况,中间有很多空格,所以我修改了一下if的判断条件,加入了一个下一个字符是数字的判断,这样就可以把整数的个数统计出来了,总体还是比较简单的.
代码区:
#include <cstdio>
#include <string.h>
#include <iostream>
using namespace std;
int main(){
string str;
int n,cnt;
cin >> n;
getchar();//这里也很重要,因为回车会被认为是第一行的结束,所以这里把那个回车吞掉
while(n--){
cnt = 0;
getline(cin,str);
for(int i = 0; i < str.length(); i++){
if(str[i]==' '&&isdigit(str[i+1]))cnt++;//确保多个空格的情况也可以判断
}
cout << ++cnt << endl;//将cnt加一再输出,因为比如两个空格代表着三个数呢
}
return 0;
}
新手上路,有错请指正;