求1!+2!+3!+...+n!,由于答案很大,答案对998244353求余即可。输入存在多组测试数据,对于每组测试数据输入一个正整数n(1<=n<=10^6)对于每组测试数据输出一行表示答案。java实现
时间: 2023-10-07 14:10:44 浏览: 68
import java.math.BigInteger;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
BigInteger mod = BigInteger.valueOf(998244353);
while (sc.hasNext()) {
int n = sc.nextInt();
BigInteger res = BigInteger.ONE;
for (int i = 1; i <= n; i++) {
res = res.multiply(BigInteger.valueOf(i)).mod(mod); // 乘积取模
}
System.out.println(res);
}
}
}
相关问题
求1!+2!+3!+...+n!,由于答案很大,答案对998244353求余即可。输入存在多组测试数据,对于每组测试数据输入一个正整数n(1<=n<=10^6)java实现
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();
}
}
要求编写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`类型来保存阶乘和计算结果。
阅读全文