我正在尝试编写一个自定义函数,它可以将任何数字'a'提升到幂'b',而我只对获得答案的真实部分感兴趣.我已经编写了自己的函数来处理,但是当a为负时它仍然会失败.可以告诉我如何解决这个问题吗?
#include <exception>
...
double power(double a, double b) {
double output;
try {output = pow(a,b);}
catch (std::domain_error) { //even if I use catch(...) I still get a NaN.
if (b==0.0) output = 1.0;
if (a==0.0) output = 0.0;
if (b<0.0) {
b=-1.0*b;
try {output = 1.0/pow(a,b);}
catch (std::domain_error){
a = -1.0*a;
output = -1.0/pow(a,b);
}}
else {
a=-1.0*a;
output = -1.0*pow(a,b);}
}
return output;
}
Run Code Online (Sandbox Code Playgroud)
非常感谢你的回复.我已阅读回复并制作了以下代码.
double power(double a, double b) {
double output;
output = pow(a,b);
if (output != output) {
if (b==0.0) output = 1.0;
if (a==0.0) output = 0.0;
else if (b<0.0) {
b=-1.0*b;
output = 1.0/pow(a,b);
if (output != output) {
a = -1.0*a;
output = -1.0/pow(a,b);
}}
else {
a=-1.0*a;
output = -1.0*pow(a,b);}
}
if (output >= DBL_MAX) output = DBL_MAX;
if (output <= -DBL_MAX) output =-DBL_MAX;
if ((output >= -DBL_MIN) && (output <= DBL_MIN)) output = 0.0;
return output;
}
Run Code Online (Sandbox Code Playgroud)
我唯一剩下的问题是c ++如何处理1.0/inf?我希望它会被抓住
if ((output >= -DBL_MIN) && (output <= DBL_MIN)) output = 0.0;
Run Code Online (Sandbox Code Playgroud)
浮点算术处理不会抛出std :: exceptions:它只返回表示异常的特殊值:
在partucular中,对于std :: pow函数,文档说:
...如果base为0且exp小于或等于0,则会发生域错误.在这种情况下返回NAN ...
它并没有说std::domain_error是抛出,而是返回NAN代表thaat异常.
由于没有throw,没有什么可以做的catch.
为了您的目的,请不要使用例外:因为您知道要处理的输入类型,只需预先过滤它即可.
| 归档时间: |
|
| 查看次数: |
705 次 |
| 最近记录: |