zoukankan      html  css  js  c++  java
  • 输入一个字符串,内有数字和非数字字符,例如:A123x456 17960? ,302tab5876,将其中连续的数字作为一个整数,依次存放到一数组a中。例如,123放在a[0],456放在a1[1].....统计共有多少个整数,并输出这些数

    输入一个字符串,内有数字和非数字字符,例如:A123x456 17960? ,302tab5876,将其中连续的数字作为一个整数,依次存放到一数组a中。例如,123放在a[0],456放在a1[1].....统计共有多少个整数,并输出这些数

    解题思路: 遇到数字字符,则开始统计连续数字字符的个数,统计完毕后,则从右往左每次乘以10(除了个位数)作为数字的单位,最终相加得到数字;然后越过这个数字,从后边继续查找。

    答案:

    #include<stdio.h>
    #include<string.h>
    
    void count_digit(char *str)
    {
    	int digit[32], count = 0;
    	char *ptr = str;
    	int i = 0, str_len = strlen(str);
    	while (i < str_len) {
    		if (*(ptr+i) >= '0' && *(ptr+i) <= '9') {
    			int len = 1;//用于统计连续数字的个数
    			while (*(ptr + i + len) >= '0' && *(ptr + i+ len) <= '9' && (i+len) < str_len) {//找出从当前位置连续数字的个数
    				len++;
    			}
    			int sum = *(ptr + i + len - 1) - '0';//先获取个位数的数据
    			int unit = 1;//每一位的单位,从十位开始每次乘以10作为单位
    			for (int j = len - 2; j >= 0; j--) {//从右往左逐个处理
    				unit *= 10;
    				sum += (*(ptr + i + j) - '0') * unit;
    			}
    			digit[count++] = sum;
    			i += len; // i需要加上len的长度,越过这个数字,防止一个连续数字中的字符重复处理
    			continue;
    		}
    		i++;
    	}
    	for (int i = 0; i < count; i++) {
    		printf("%d ", digit[i]);
    	}
    	return;
    }
    int main()
    {
    	char buf[1024] = { 0 };
    	printf("Please enter a string with numbers:
    ");
    	gets_s(buf, 1024);
    	count_digit(buf);
    	printf("
    ");
    	system("pause");
    	return 0;
    }
    
    

    输入一个字符串,内有数字和非数字字符,例如:A123x456 17960? ,302tab5876,将其中连续的数字作为一个整数,依次存放到一数组a中。例如,123放在a[0],456放在a1[1].....统计共有多少个整数,并输出这些数

  • 相关阅读:
    开放GIS标准OGC之路(4)之 解密Filter(摘抄)
    在WCF中使用async/await 关键字的简化的异步编程模型(译)
    WinCE仿真器设置
    oracle PL/SQL编程详解
    oracle 日期格式
    钢笔工具使用教程
    使用Signature Tool自动生成P/Invoke调用Windows API的C#函数声明
    利用bitmap将图片部分颜色透明
    PS圆角图片并保留透明背景
    Script Debugger的使用
  • 原文地址:https://www.cnblogs.com/cyuyanchengxu/p/13425148.html
Copyright © 2011-2022 走看看