翻译
T,p = map(int,input().split())my_list = []
for i in range(T):
my_list.append(int(input()))
def a(x):
s = 1
for i in range(1,x+1):
s = s*i
return s
for i in my_list:
b = a(i)
while b%p == 0:
b = b/p
b = b%p
print(int(b))
翻译成C++ 以下是将给定的Python代码翻译成C++的版本:
#include <iostream>
#include <vector>
using namespace std;
int main() {
int T, p;
cin >> T >> p;
vector<int> my_list(T);
for (int i = 0; i < T; i++) {
cin >> my_list[ i];
}
int b;
for (int i = 0; i < T; i++) {
b = 1;
for (int j = 1; j <= my_list[ i]; j++) {
b *= j;
}
while (b % p == 0) {
b /= p;
}
b %= p;
cout << b << endl;
}
return 0;
}
这段C++代码与原始的Python代码实现了相同的功能。它使用了 vector 来存储输入的整数列表,并使用循环和条件语句来计算和输出结果。 这是一个Python程序,它读取两个输入T和p,然后读取T个整数,对每个整数i,它计算i的阶乘,然后除以p,直到结果不再是p的倍数。然后它取模p并打印结果。以下是这个程序的C++版本:
#include <iostream>
#include <vector>
using namespace std;
long long factorial(int x) {
long long s = 1;
for (int i = 1; i <= x; i++) {
s = s * i;
}
return s;
}
int main() {
int T, p;
cin >> T >> p;
vector<int> my_list(T);
for (int i = 0; i < T; i++) {
cin >> my_list[ i];
}
for (int i : my_list) {
long long b = factorial(i);
while (b % p == 0) {
b = b / p;
}
b = b % p;
cout << b << endl;
}
return 0;
}
请注意,这个C++版本的程序在处理大阶乘时可能会遇到溢出问题,因为C++的long long类型的最大值是9223372036854775807。如果输入的数字大于20,阶乘函数将返回不正确的结果。为了处理这个问题,你可能需要使用一些库,如Boost或GMP,它们提供了可以处理大整数的类型。
请注意,本回答来自GPT-4
如果问题已经解决,请设置最佳答案 以下是将给定的Python代码翻译为C++的版本:
#include <iostream>
#include <vector>
using namespace std;
int factorial(int x) {
int result = 1;
for (int i = 1; i <= x; i++) {
result *= i;
}
return result;
}
int main() {
int T, p;
cin >> T >> p;
vector<int> my_list(T);
for (int i = 0; i < T; i++) {
cin >> my_list;
}
for (int i : my_list) {
int b = factorial(i);
while (b % p == 0) {
b /= p;
}
b %= p;
cout << b << endl;
}
return 0;
}
希望对你有帮助,如有疑问请继续追问。
球一个最佳答案谢谢啦!这对我非常重要!{:10_254:}{:10_254:}{:10_254:}
页:
[1]