转换表实现简单计算器

        ## **转换表** ##

转换表 : 一个函数指针数组

创建一个转换表需要两个步骤,
1,声明并初始化一个函数指针数组,并确保这些函数原型出现在这个数组声明之前。
double add(double, double);//加
double sub(double, double);//减
double mul(double, double);//乘
double div(double, double);//除

double (*oper_func[]) (double, double) = {
add,sub,mul,div, …
};

第二个步骤是用下面这条语句代替复杂的switch语句!
result = oper_func[oper] (op1,op2);
oper 从数组中选择正确的函数指针,而函数调用操作符将执行这个函数。

转换表 实现 计算器
代码实现 :

#include<stdio.h>
#include<string.h>
#include<assert.h>

double add(double i, double j)//加
{
    return  i + j;
}
double sub(double i, double j)//减
{
    return i - j;
}
double mul(double i, double j)//乘
{
    return i * j;
}
double div(double i, double j)//除
{
    return i / j;
}

int main()
{
    int oper =  0; //操作符必须为整型
    double op1,op2;
    scanf("%d",&oper); //输入操作符 来 决定使用哪一项功能
    scanf("%lf %lf",&op1, &op2);
    //转换表, 函数指针实现
    double (*oper_func[])(double,double) = {
        add,sub,mul,div
    };
    double result = (*oper_func[oper])(op1,op2);
    printf("%lf", result);
    return 0;
}

使用上面的函数就可以实现简单的加减乘除,而不需要使用swictch case那么多行的代码了,使用转换表,简化代码量,通俗易懂。

猜你喜欢

转载自blog.csdn.net/xzg_2017/article/details/80892473
今日推荐