输入一个字符串,内有数字和非数int字符,如a123x456,将其中连续的数作为一个整数,依次存放到整形数组a中。

该C程序从包含字母和数字的字符数组中,通过遍历并判断字符是否为数字,提取出所有的整数并存储到整型数组中。程序使用了两个循环,外层循环用于找到数字的开始,内层循环计算数字的值。最后,程序打印出提取的整数个数及整数值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<stdio.h>

int main(int argc, char const *argv[])

{

char buf[32]="a123b456";

int a[32]={};

int i=0,j=0,sum=0;

char *p = buf;

while(*p)

{

if(*p < '0'|| *p > '9')

{

p++;

continue;

}

while(*p >= '0'&&*p <= '9')

{

sum = sum*10 + *p -48;

p++;

}

a[i] = sum;

sum = 0;

i++;//存放整数的个数

}

printf("一共有%d个整数,他们分别是:\n",i);

while(j<i)

{

printf("%d ",a[j]);

j++;

}

printf("\n");

return 0;

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

SaberTimo

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

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

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

打赏作者

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

抵扣说明:

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

余额充值