黎子卿 发表于 2023-10-22 18:32:27

翻译

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++

isdkz 发表于 2023-10-22 18:32:47

以下是将给定的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 来存储输入的整数列表,并使用循环和条件语句来计算和输出结果。

陶远航 发表于 2023-10-22 18:32:56

这是一个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
如果问题已经解决,请设置最佳答案

Mike_python小 发表于 2023-10-22 18:33:13

以下是将给定的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]
查看完整版本: 翻译