输入一个字符串,内有数字和非数字字符,如:ak123x456 17960? 302gef4563,将其中连续的数字作为一个整体,依次存放到一数组a中,例如123放入a[0],456放入a[1]...编程统计共有多少个整数,并输出这些数。用c语言编程
时间: 2024-10-09 11:14:07 浏览: 60
在C语言中,你可以使用`strtok()`函数结合循环来解决这个问题。下面是一个简单的示例程序:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义一个函数来找出字符串中的数字串并存储到数组中
void find_numbers(char* str, int count[], char** arr) {
char* token = strtok(str, "0123456789"); // 分割符为所有数字
int num_count = 0;
while (token != NULL) {
*arr[num_count] = token; // 存储数字串到数组
count[num_count++] = strlen(token); // 记录长度作为整数
token = strtok(NULL, "0123456789");
}
}
int main() {
char str[] = "ak123x456 17960? 302gef4563";
int num_count = 0;
char* numbers[100]; // 预估最多100个数字
find_numbers(str, &num_count, numbers);
printf("Total number of integers found: %d\n", num_count);
for (int i = 0; i < num_count; i++) {
printf("Number at index %d: %s (length %d)\n", i, numbers[i], numbers[i][strlen(numbers[i]) - 1]); // 输出最后一个字符判断是否整数
}
return 0;
}
```
这个程序首先使用`strtok()`找到字符串中的每个数字串,然后计算它们的数量并将结果存储在`count[]`数组中。同时,它也将找到的数字串存储到`numbers[]`数组中。注意,为了简单起见,我们通过查看最后一个字符是否为数字来粗略地检查是否整个字符串都是整数。
阅读全文