以下是解决此问题的 C++ 代码: ```cpp #include <iostream> int gcd(int a, int b) { if (b == 0) { return a; } return gcd(b, a % b); } void solve(int n, int m) { double p = static_cast<double>(m) / n; double res = 1; for (int i = 0; i < 3; ++i) { res *= p; } if (res == 1) { std::cout << 1 << std::endl; } else if (res == 0) { std::cout << 0 << std::endl; } else { int num = static_cast<int>(res * 1000000); int den = 1000000; int g = gcd(num, den); std::cout << num / g << "/" << den / g << std::endl; } } int main() { int k; std::cin >> k; while (k--) { int n, m; std::cin >> n >> m; solve(n, m); } return 0; } ``` 以下是三个改进建议: 1. 可以添加一些输入错误处理,比如当输入的 n 或 m 不符合要求时给出提示。 2. 可以将 `gcd` 函数提取为一个单独的头文件,以提高代码的可维护性。 3. 对于输出的分数形式,可以添加一些注释来解释其含义,增强代码的可读性。 [2024-12-27 17:56:25 | AI写代码神器 | 390点数解答]