设计一个名为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)
";
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;
}