解题思路:
(1)计算阶乘别用递归,除了装比没别的用处;
(2)计算n次幂要考虑0次幂的情况。
注意事项:
while (n--) 和 while (--n) 何时结束循环要分清。
参考代码:
#include #include #include using namespace std; // 计算阶乘 double fact(int n) { double res = n; while (--n) { res *= n; } return res; } // 计算n次幂 double mypow(double x, int n) { double res = x; if (!n) { return 1; // 0次幂 } while (--n) { res *= x; } return res; } int main() { double x = 0; int n = 0; cin >> x >> n; // 未对x非正数做异常处理,也通过了 double res = 0; for (int i = 0; i < n; ++i) { res += (mypow(-1, i) * mypow(x, i + 1) / fact(i + 1)); } cout << fixed << setprecision(4) << res << endl; return 0; }
0.0分
1 人评分