• 编写程序简单实现计算器:加减乘除功能(函数指针数组的写法)


    编写程序简单实现计算器:加减乘除功能(函数指针数组的写法)!

    这篇博文,笔者主要还是对编写计算器,求出加减乘除四则运算的精华版!

    对于笔者上篇博文,笔者简单讲解了,粗略的代码,编写出计算器的加减乘除四则运算!但是代码显得臃肿,华而不实,因此,笔者打算在此篇博文中,进行一些简简单单的优化,以便于用少量代码来更好的实现目的!

    1.其实代码段大致还是跟上篇博文内容差不多类似!下面笔者对于相似的部分进行简单的引用,在此,笔者就不再进行过多的讲述(当然,建议有想法的读者去看一下笔者的上篇博客)!

    相似部分的代码段为:

    1. //简化一下代码
    2. #include
    3. int Add(int x, int y)
    4. {
    5. return x + y;
    6. }
    7. int Sub(int x, int y)
    8. {
    9. return x - y;
    10. }
    11. int Mul(int x, int y)
    12. {
    13. return x * y;
    14. }
    15. int Div(int x, int y)
    16. {
    17. return x / y;
    18. }
    19. void menu()
    20. {
    21. printf("***************************\n");
    22. printf("***** 1.add 2. sub ****\n");
    23. printf("***** 3.mul 4. div ****\n");
    24. printf("***** 0.exit ****\n");
    25. printf("***************************\n");
    26. }

    上述代码的步骤,笔者就不做更多的讲述,下面请看笔者的更改部分!

    1. int main()
    2. {
    3. int input = 0;
    4. int x = 0;
    5. int y = 0;
    6. int ret = 0;
    7. //函数指针数组 - 转移表
    8. int (*pfArr[])(int, int) = { 0, Add, Sub, Mul, Div };
    9. do
    10. {
    11. menu();
    12. printf("请选择:>");
    13. scanf_s("%d", &input);
    14. if (input == 0)
    15. {
    16. printf("退出计算器\n");
    17. break;
    18. }
    19. if (input >= 1 && input <= 4)
    20. {
    21. printf("请输入2个操作数:>");
    22. scanf_s("%d %d", &x, &y);
    23. ret = pfArr[input](x, y);
    24. printf("%d\n", ret);
    25. }
    26. else
    27. {
    28. printf("选择错误\n");
    29. }
    30. } while (input);
    31. return 0;
    32. }

    在这里,对于input输入之后,直接进行判定,如果:input==0  ,则进行退出计算器,否则,则进行判断: input >= 1 && input <= 4,对于判断的结果,将决定选择那个进行打印!

    在: ret = pfArr[input](x, y);       printf("%d\n", ret);     input又当作了数组的下标!然后调用: int (*pfArr[])(int, int) = { 0, Add, Sub, Mul, Div };    这个主要是:函数指针数组!对于垫了一个: 0,主要是数组的首元素下标为:0,数组是从:0开始进行的!

    因此总的来说,是符合题意的!

    1. if (input >= 1 && input <= 4)
    2. {
    3. printf("请输入2个操作数:>");
    4. scanf_s("%d %d", &x, &y);
    5. ret = pfArr[input](x, y);
    6. printf("%d\n", ret);
    7. }
    8. else
    9. {
    10. printf("选择错误\n");
    11. }

    上述代码片段尤为重要,其实只要笔者写出来,对于大部分读者,都能看出来大致意思!

    因此总的代码为:

    1. //简化一下代码
    2. #include
    3. int Add(int x, int y)
    4. {
    5. return x + y;
    6. }
    7. int Sub(int x, int y)
    8. {
    9. return x - y;
    10. }
    11. int Mul(int x, int y)
    12. {
    13. return x * y;
    14. }
    15. int Div(int x, int y)
    16. {
    17. return x / y;
    18. }
    19. void menu()
    20. {
    21. printf("***************************\n");
    22. printf("***** 1.add 2. sub ****\n");
    23. printf("***** 3.mul 4. div ****\n");
    24. printf("***** 0.exit ****\n");
    25. printf("***************************\n");
    26. }
    27. int main()
    28. {
    29. int input = 0;
    30. int x = 0;
    31. int y = 0;
    32. int ret = 0;
    33. //函数指针数组 - 转移表
    34. int (*pfArr[])(int, int) = { 0, Add, Sub, Mul, Div };
    35. do
    36. {
    37. menu();
    38. printf("请选择:>");
    39. scanf_s("%d", &input);
    40. if (input == 0)
    41. {
    42. printf("退出计算器\n");
    43. break;
    44. }
    45. if (input >= 1 && input <= 4)
    46. {
    47. printf("请输入2个操作数:>");
    48. scanf_s("%d %d", &x, &y);
    49. ret = pfArr[input](x, y);
    50. printf("%d\n", ret);
    51. }
    52. else
    53. {
    54. printf("选择错误\n");
    55. }
    56. } while (input);
    57. return 0;
    58. }
    59. #include
    60. void menu()
    61. {
    62. printf("***************************\n");
    63. printf("***** 1.add 2. sub ****\n");
    64. printf("***** 3.mul 4. div ****\n");
    65. printf("***** 0.exit ****\n");
    66. printf("***************************\n");
    67. }
    68. int main()
    69. {
    70. menu();
    71. return 0;
    72. }

    因此,总的代码就已经结束!

    具体的运转结果为:

    所以,笔者的代码到此已经结束,所以就不做更多的讲述!读者若有更多的想法,请联系笔者进行更改!

  • 相关阅读:
    Nest.js开发
    [ATC复盘] abc329 20231118
    抽象方法与设计模式
    PMP 考试需要注意哪些事项?
    PROB: Probabilistic Objectness for Open World Object Detection(论文解析)
    Apache hudi 核心功能点分析
    翻墙工作?承德程序员被罚款 108 万元!
    Java SPI机制
    Pytorch训练神经网络完整步骤:搭建一个完整的神经网络(以用于Mnist手写数字识别的卷积神经网络为例)
    如何使用记事本制作一个简陋的小网页(1)
  • 原文地址:https://blog.csdn.net/weixin_64308540/article/details/126318380