.输入一个字符串,内有数字和非数字字符,例如:A123x456 17960? 302tab5876 将其中连续的数字作为一个整数,依次存放到已数组a中,例如,123放在a[0],456放在a[1]…

#include<stdio.h>
int jishu(char *p)
{
    int a[10]={0};
    int i=0,j=0,b=0;
    for(i=0;*(p+i)!='\0';i++)
    {
    if(*(p+i)>='0'&&*(p+i)<='9')
    {
         b=*(p+i)-48+b*10;
         //如果检测到数字减去48=本身,b*10位数递增 
    }
    if((*(p+i+1)<'0'||*(p+i+1)>'9')&&b!=0)
    {
         a[j]=b;j++;b=0;
         //检测到非数字将整数b赋值给数组a的元素,b重置 
    }        
    }

    printf("一共有%d个整数,分别为:\n",j);
    for(i=0;i<j;i++)
    printf("%d\t",a[i]);   
}
int main()
{
    char s[]={"A123x456 17960? 302tab5876"};
    jishu(s);
}

习题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`将会保存从输入字符串中提取出的所有连续整数
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值