比如abc123ef
输出123
123423ef
输出123423
我的思路是这样的,遍历每个字符,如果是数字那么就把它放入另外一个数组里面,然后把另外一个全是数字的数组里面,取出一个数字乘以权重 ,连加起来。
#include "stdio.h" #include "stdlib.h" #include "math.h" int main(int argc, char *argv[]) { char string[20] = {0}; int num[20] = { 0}; int count = 0; int sum = 0; scanf_s("%s",string,20); int j = 0; for (int i = 0; i < 20; i++) { if (string[i] >= 0x30 && string[i] <= 0x39) { num[j++] = string[i] - 0x30; count++; } } for (int i = 0; i < 20; i++) { sum = num[i] * pow(10, count - 1) + sum; count--; } printf("%d",sum); system("pause"); return 1; }
但是不支持123abc456 这样的字串,结果是123456。