c语言求1平方+2平方+...+n平方
时间: 2023-12-29 07:04:44 浏览: 107
以下是C语言求1平方+2平方+...+n平方的代码示例:
```c
#include <stdio.h>
int main() {
int n, sum = 0;
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
sum += i * i;
}
printf("%d\n", sum);
return 0;
}
```
该程序首先读取一个整数n,然后使用for循环计算1到n的平方和,并将结果存储在变量sum中。最后,程序输出sum的值。
相关问题
c语言递归求1+2²+3²+...+n²
这是一个经典的递归问题。可以使用递归函数来解决。递归函数的基本思路是:如果n等于1,则返回1的平方;否则,返回n的平方加上n-1的平方和。下面是一个C语言递归求1+2²+3²+...+n²的示例代码:
```
#include <stdio.h>
int sum(int n) {
if (n == 1) {
return 1;
} else {
return n * n + sum(n - 1);
}
}
int main() {
int n = 10;
printf("1^2 + 2^2 + ... + %d^2 = %d\n", n, sum(n));
return 0;
}
```
这个程序使用了递归函数sum来计算1²+2²+3²+...+n²的值。在sum函数中,如果n等于1,则返回1的平方;否则,返回n的平方加上n-1的平方和。在主函数中,我们调用sum函数来计算1²+2²+3²+...+n²的值,并将结果打印出来。
C语言1!+2!+3!+...+20!
以下是C语言实现1!+2!+3!+...+20!的代码和解释:
```c
#include <stdio.h>
long long get_factorial(int num); // 声明一个函数,用于计算阶乘
int main() {
long long sum = 0; // 定义一个变量,用于存储阶乘和
int i = 0;
for(i = 1; i <= 20; i++) { // 循环计算1!到20!的和
sum += get_factorial(i);
}
printf("1!+2!+...+20!的和为%lld\n", sum); // 输出结果
return 0;
}
// 计算阶乘的函数
long long get_factorial(int num) {
if(num >= 1) {
return num * get_factorial(num - 1); // 递归调用自身,计算阶乘
} else {
return 1; // 0! = 1
}
}
```
运行结果为:1!+2!+...+20!的和为2561327494111820313
--相关问题--:
1. 如何在C语言中计算一个数的平方?
2. 如何在C语言中实现字符串反转?
3. 如何在C语言中实现冒泡排序?