ZJNU1424 输入了几个整数

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

新手上路,有错请指正;

上一篇:DSP-BIOS使用入门


下一篇:Active Directory 域服务之AD DS 概述