求1!+2!+3!+...+n!,由于答案很大,答案对998244353求余即可。输入存在多组测试数据,对于每组测试数据输入一个正整数n(1<=n<=10^6)java实现
时间: 2023-10-07 13:12:57 浏览: 120
import java.math.BigInteger;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
BigInteger mod = BigInteger.valueOf(998244353); // 模数
while (scanner.hasNext()) {
int n = scanner.nextInt();
BigInteger ans = BigInteger.ONE; // 结果初始化为1
for (int i = 1; i <= n; i++) {
ans = ans.multiply(BigInteger.valueOf(i)); // 乘上i
ans = ans.mod(mod); // 取模
}
System.out.println(ans);
}
scanner.close();
}
}
相关问题
用Python代码写给定正整数n,求不大于n的正整数的阶乘的和(即求1! +2! +3! +...+n!输入:一个正整数n (1<n<12) 输出: 不大于n的正整数的阶乘的和。
好的,我来给您写一段代码:
```python
n = int(input("请输入一个正整数n:"))
sum = 0
factorial = 1
for i in range(1, n+1):
factorial *= i
sum += factorial
print("不大于n的正整数的阶乘的和为:", sum)
```
这段代码首先让用户输入一个正整数n,然后使用一个for循环,从1到n遍历每个正整数。在循环体中,计算当前正整数的阶乘,并将其加到一个变量sum中。最后输出sum即可。
需要注意的是,当n比较大时,阶乘的值很容易溢出。因此,这段代码只适用于比较小的n值。
要求编写c语言程序,对于给定的正整数n,要求编程计算S=1!+2!+3!+...+n!输入一个不超过10的正整数n。
要计算S=1!+2!+3!+...+n!,可以使用循环结构来实现。首先,需要定义一个变量sum来保存计算结果,初始值为0。然后,使用一个循环从1到n,每次迭代计算当前数的阶乘,并将结果累加到sum中。最后,输出sum的值即可。
以下是一个示例的C语言程序:
```c
#include <stdio.h>
int main() {
int n, i;
long long factorial = 1;
long long sum = 0;
printf("请输入一个不超过10的正整数n:");
scanf("%d", &n);
for (i = 1; i <= n; i++) {
factorial *= i;
sum += factorial;
}
printf("S = %lld\n", sum);
return 0;
}
```
请注意,由于阶乘的结果可能会很大,所以使用了`long long`类型来保存阶乘和计算结果。
阅读全文