文章作者:Tyan
博客:noahsnail.com | CSDN | 简书
1. 枚举
枚举是基于逐个尝试答案的一种问题求解策略。
2. 完美立方
形如$a^3 = b^3 + c^3 + d^3$的等式被称为完美立方等式。例如$12^3 = 6^3 + 8^3 + 10^3$
问题:编写程序,对任给的正整数N(N<=100),寻找所有的四元组(a, b, c, d),使得$a^3 = b^3 + c^3 + d^3$,其中a,b,c,d大于1,小于等于N,且b<=c<=d。
输入:一个正整数N(N<=100)。
输出:每行输出一个完美立方。输出格式为Cube = a,Triple = (b, c, d)。
求解:
备注:判断条件边界很重要
- 方法一:
1 | #!/usr/bin/env python |
- 输出
1 | Cube = 6, Triple = (3, 4, 5) |
- 方法二
1 | #!/usr/bin/env python |
- 输出
1 | Cube = 6, Triple = (3, 4, 5) |
从上面可以看出枚举的边界不同,效率会差将近三倍。
Python源码地址:https://github.com/SnailTyan/programming-and-algorithms/blob/master/perfect_cubes.py,记得给个star。
C++源码地址(已在POJ上Accepted):https://github.com/SnailTyan/programming-and-algorithms/blob/master/perfect_cubes.cpp,记得给个star。