OJ 从字符串中解析整数

描述
给定一个字符串,其中含有数字字符和非数字字符,将其中的连续数字字符作为整数。输出这样的整数,并指出其个数。给定一个字符串,其中含有数字字符和非数字字符,将其中的连续数字字符作为整数。输出这样的整数,并指出其个数。

输入
输入数据有若干行,每行上有一个字符串对应一种情形。字符串中的整数个数不超过10000个,字符串的长度不超过65536字符。

输出
对于每一种情形,先输出“Case #:”(#为序号,从1起),然后输出其中整数的个数(加括号),及具体的数值,换行。

样例输入1
a123x456U17960?302t ab5876
202.120.127.211
1st8.35t3
abc defg
样例输出1
Case 1: (5) 123 456 17960 302 5876
Case 2: (4) 202 120 127 211
Case 3: (4) 1 8 35 3
Case 4: (0)

在经历数次WA后,发现了导致WA的小细节:

  1. 无整数,输出右括号后直接换行,没有空格
  2. 有整数,最后一个数字输出后直接换行,没有空格

AC代码:

#include <iostream>
#include <cstring>
using namespace std;

const int N = 20000;
char str2[N];
string str1;

int main()
{
    int t = 0;
    while(getline(cin, str1))
    {
        memset(str2, '\0', N);      //初始化数组str2
        str2[0] = ' ';              //对第一个元素赋初值' ',便于后面输出
        t ++;                       //情形序号递增
        int count = 0, i, j = 1, k;
        for(i = 0; i < str1.length(); i ++)
        {
            if(str1[i] >= '0' && str1[i] <= '9')
            {
                str2[j++] = str1[i];//提取数字
                if(str1[i+1] >= '0' && str1[i+1] <= '9')
                    continue;
                str2[j++] = ' ';    //后一位是数字,继续循环;不是数字,写一个空格
            }
        }
        str2[j - 1] = '\0';         //将最后一个空格改为'\0',防止输出中多出一个空格
        for(i = 1; i <= j - 2; i ++)
            if(str2[i] >= '0' && str2[i] <= '9' && (str2[i+1] == ' ' || str2[i+1] == '\0'))
                count ++;           //统计数字个数
        cout << "Case " << t << ": (" << count << ")";
        if(count != 0)
            cout << str2;           //输出具体数字
        cout << endl;
    }
    return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hibiki.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值