C++ 优化:解决小明 a+b 练习抽题正确率计算代码的改进方案
```cpp #include <iostream> #include <iomanip> int gcd(int a, int b) { if (b == 0) { return a; } return gcd(b, a % b); } int main() { int k; std::cin >> k; while (k--) { int n, m; std::cin >> n >> m; // 计算组合数C(n, m) long long numerator = 1, denominator = 1; for (int i = 0; i < m; ++i) { numerator *= (n - i); denominator *= (i + 1); int g = gcd(numerator, denominator); numerator /= g; denominator /= g; } // 计算抽到的三题都正确的概率 long double probability = (long double)(numerator * numerator) / (denominator * denominator * denominator); if (probability == 1.0 || probability == 0.0) { std::cout << std::fixed << std::setprecision(0) << probability << std::endl; } else { std::cout << numerator << "/" << denominator * denominator << std::endl; } } return 0; } ``` 改进建议: 1. 使用更具表达性的变量名以提高代码可读性。 2. 将计算组合数的部分提取成一个单独的函数,以提高代码的模块化和复用性。 3. 考虑在计算组合数时,使用动态规划来优化计算速度。 ######[AI写代码神器 | 793点数解答 | 2024-12-27 17:57:22]
- Python实现好友通讯录信息增删改查功能,附示例代码( | 1248点数解答 | 2024-04-23 17:34:25)302
- 工程师必备:十大APP性能优化方案大揭秘(百度文心 | 300点数解答 | 2023-11-09 18:31:04)350
- 含不规则缺陷原材料的最优切割方案建模与损失率、利用率计算(DeepSeek | 2367点数解答 | 2025-05-10 23:47:30)281
- 解析React 15与Vue 2:从O(n^3)到O(n),Diff算法时间复杂度计算及性能对比 (阿里通义 | 379点数解答 | 2023-11-09 01:49:19)353
- 缜密逻辑,全新无名杀“风餐”技能代码精心打造与深度解析 (字节豆包 | 469点数解答 | 2025-04-05 11:37:06)267
- 精准优化:明确需求,开启高效提升之旅! (字节豆包 | 52点数解答 | 2026-02-09 16:44:46)58
- 代码再升级:优化版“获取dump”代码,多机制保障数据读取与保存(字节豆包 | 734点数解答 | 2026-02-10 01:23:31)83
- 代码深度优化:全面检查异常、灵活读取内存,提升可读性与可维护性(字节豆包 | 959点数解答 | 2026-02-10 01:24:14)55
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)95
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)53
- 破解Jenkins构建Java项目“数据收集等待过长”难题的实用攻略( | 389点数解答 | 2024-01-18 09:27:30)340
- Jenkins 构建 Java 项目“数据收集等待过长”难题的 10 大解决策略(百度文心 | 551点数解答 | 2024-01-18 09:27:54)297