用C实现,考虑内存越界和范围,描述 给定一个正整数n(n <= 200),计算1! + 2! + 3! + ... + n!。 例如,输入数字为3,则输出结果为9(1! + 2! + 3! = 1 + 2*1 + 3*2*1 = 9) 输入描述 正整数n(n <= 200) 输出描述 计算并打印1! + 2! + 3! + ... + n!的值。如果输入的n不是数字,或者是数字但不是正整数,或者n > 200,则输出字符串error。
时间: 2023-09-30 22:03:27 浏览: 69
C语言入门-leetcode练习之第41题缺失的第一个正数.zip
好的,这是一个比较典型的需要使用循环和递归的问题。以下是用C语言实现的代码:
```c
#include<stdio.h>
int factorial(int n) {
if(n == 0) {
return 1;
} else {
return n * factorial(n-1);
}
}
int main() {
int n;
int sum = 0;
if(scanf("%d", &n) == 1) { // 判断输入是否为数字
if(n <= 0 || n > 200) { // 判断输入是否为正整数且不大于200
printf("error");
} else {
for(int i = 1; i <= n; i++) {
sum += factorial(i);
}
printf("%d", sum);
}
} else {
printf("error");
}
return 0;
}
```
首先,我们定义了一个 `factorial` 函数,用于计算阶乘。使用递归的方式来实现,如果传入的参数为0,则返回1,否则返回n与 `factorial(n-1)` 的乘积。
然后,在 `main` 函数中,我们先使用 `scanf` 函数判断输入是否为数字,如果是,则继续判断是否为正整数且不大于200。如果是,则使用循环来计算1!到n!的和,并将结果保存在 `sum` 变量中。最后输出 `sum` 的值。
如果输入不符合要求,则输出字符串 "error"。
在实现过程中,我们需要注意内存越界和范围的问题,确保程序的正确性和稳定性。
阅读全文