输入一个字符串内有数字和非数字字符,例如:A123x456...

#include <stdio.h>
#include <string.h>
#include <math.h>
int main()
{

void sum_output(char s[],int *pn,int *pi);              //字符串数组、两个指针变量作形参
char str[100];
int i=0,num[15],inter[25];                              //num数组用来存放找到的数字,inter数组存放找到的整数
printf("input string:\n");
while((str[i]=getchar())!='\n')
     i++;
str[i]='\0';
sum_output(str,num,inter);                              //将字符串首字符地址传递到sum_output函数,num,inter数组首元素地址通过形参传递
return 0;

}
void sum_output(char s[],int *pn,int *pi)
{

int i,j,t,sum,o,flag=0,k=0,*pi1;
pi1=pi;                                                 
t=strlen(s);
for(i=0;i<t;i++)
{
	if(*(s+i)>='0'&&*(s+i)<='9')
	{	
		*pn++=*(s+i)-'0';                                //把字符类型数字转换成整数类型数字赋给num数组
		k++;
		flag=1;
	}
	else
	{
		if(flag==1)
		{
		  sum=0;
		  for(j=0;j<k;j++)
		  {
			 o=pow(10,k-1-j)*(*(pn-k+j));                //调用pow函数把num数组中的数字转换成十进制整数
		     sum=sum+o;
		  }
		  *pi++=sum;
		  flag=0;
		  k=0;
		  
		}
	}
}
if(k!=0)                                                 //考虑最后一个字符为数字的情况
{  
   sum=0;
   for(j=0;j<k;j++)
   {
	   o=pow(10,k-1-j)*(*(pn-k+j));
	   sum=sum+o;
   }
   *pi++=sum;
}
*pi='\0';
printf("integers: ");
for(i=0;*(pi1+i)!='\0';i++)
	printf("%d ",*(pi1+i));
printf("\nnumber:%d\n",i);

}

运行结果:
在这里插入图片描述

习题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、付费专栏及课程。

余额充值