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

#include <stdio.h>
#include <string.h>
void fac() {
	char str1[50],* p;
	int temp,sum=0,i=0,str2[50];
	printf("input str1:\n");
	/*scanf("%s", str1);*/// scanf()函数获取字符串遇到空格结束输入
	gets(str1);
	for (p =str1; p<str1+ strlen(str1); p++)
	{
		if (*p >= '0' && *p <= '9')
		{
			temp = 0;//临时变量,每次清零;
			temp = *p - '0';//将字符数字转换成整型数字
			if (*(p+1)>='0'&& *(p+1)<='9')
				sum = (sum + temp) * 10;
			else//如果下一个不是数字,则当前字符是整数的个位,不乘10
				sum+=temp,
				str2[i] = sum,//并且将找到的整数存到整型数组里面
				i++,
				sum = 0;//sum清零,以便记录下一个整数
		}
	}
	printf("\nresult:\n");
	for (int *q=str2; q<(str2+i); q++)
		printf("%d ",*q);
}
int main() {
	fac();
	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`将会保存从输入字符串中提取出的所有连续整数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值