输入字符串,内有数字和非字符数组,例如A123x456将其中连续的数字作为一个整数,依次存放到一个数组中,如123放到a[0],456放到a[1],并输出a这些数

#include "stdio.h"
#include "string.h"
#include "math.h"
int isdigit(char c)
{
    if(c>47 && c<58)
    {
        return 1;
    }
    
    return 0;
}
char *s_gets(char *st,int size);
int main()
{
char str[30],str1[10][10],*end;
int t=0,m=0,i,digit_num=0;long a[9];
printf("请输入一个字符串:");
s_gets(str,30);
for(i=0;i<strlen(str);i++)
{

if(isdigit(str[i]))
{
    str1[m][t]=str[i];
    t++;
    digit_num++;
}
else
{
    
    if(t!=0)
    {
    str1[m][t]='\0';
    
//    a[m]=strtol(str1[m],&end,10);
    t=0;
    m++;
    }
}
printf("%c",str[i]);
}
printf("共有%d位数字",digit_num);
for(i=0;i<=m;i++)
printf(" %s",str1[i]);
return 0;
}
char *s_gets(char *st,int size)
{
char *ret_val;
int i=0;
ret_val=fgets(st,size,stdin);
if(ret_val)
{
while(st[i]!='\0'&&st[i]!='\n')
i++;
if(st[i]='\n')
st[i]='\0';
else
while(getchar()!='\n')
continue;
}
return ret_val;
}
习题6.16描述的是一个涉及字符串处理递归操作的问题。目标是读取输入字符串,找出其中连续数字序列,将它们作为整数存储到数组`a`中。这里是一个基本的解决方案: 首先,我们可以创建一个,假设命名为`parseNumbers`,它接受两个参:当前处理的字符串(初始为空),以及结果数组。这个函会检查字符串的第一个字符,如果它是数字,就进入递归过程;如果不是,则结束递归返回。 递归过程如下: 1. 如果当前字符数字: - 将该字符添加到临时数字字符串(如`tempStr`)中。 - 调用自身,传入更新后的字符串数组(继续查找下一个数字)。 2. 如果当前字符不是数字,或者遇到数字字符后结束: - 检查`tempStr`是否包含有效的整数。如果是,将其转换为整数添加到数组`a`中。 - 清空`tempStr`,因为已经处理了一个数字串。 - 返回当前字符串(即处理完当前数字后的剩余部分)。 下面是一个伪代码形式的示例: ```python def parseNumbers(s, a): tempStr = "" if s[0].isdigit(): tempStr += s[0] return parseNumbers(s[1:], a) else: if tempStr != "": a.append(int(tempStr)) return s input_str = "a123x456 17960? 302tab5876" result_array = [] numbers = parseNumbers(input_str, result_array) ``` 当你运行这个程序后,`result_array`将会保存从输入字符串中提取出的所有连续整数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值