设计一个名为calculate()的函数,他接受两个double 值和一个指向函数的指针,而被指向的函数接受两个double参数,并返回一个double值 calculate()函数的类型也是double,并返回被指向的函数值用calculate()的两个double参数计算得到的值。例如,假设add()函数的定义如下:
double add(double x,double 有)
{
return x+y;
}
则下述代码中的函数调用将导致calculate()把2.5和10.4传递给add()函数,并返回add()的返回值(12.9):
double q = calculate(2.5, 10.4, add);
编写一个程序,它调用上述两个函数和至少另一个于add()类似的函数。该程序使用循环来让用户成对地输入数字。对于每对数字,程序都使用calculate()来调用add()和至少一个其他的函数。如果读者爱冒险,可以尝试创建一个指针数组,其中地指针指向add()样式地函数,并编写一个循环,使用这些指针连续让calculate()调用这些函数。提示:下面是声明这种指针数组地方式,其中包含三个指针: double(*pf【3】)(double, double);
可以采用数组初始化语法,并将函数名作为地址来初始化这样的数组。
#include<iostream>
double calculate(double, double, double(*p)(double, double));
double add(double, double);
double minus(double, double);
int main(void) {
using std::cin; using std::cout;
double (*pf[2])(double, double)={add, minus};
double x,y; cout << "Input the data to calculate(q to quit)\n";
while(cin >> x >> y) {
for(size_t i=0; i<2; i++) {
cout << calculate(x,y,(*pf[i])) << std::endl;
}
}
return 0;
}
double calculate(double x, double y, double(*p)(double, double)) {
return (*p)(x, y);
}
double add(double x, double y) { return x+y; }
double minus(double x, double y) { return x-y; }