简单计算器的实现(含转移表实现)

简介: 简单计算器的实现(含转移表实现)

计算器的一般实现

通过函数的调用,实现加减乘除

# define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int Add(int x, int y) {
  return x + y;
}
int Sub(int x, int y) {
  return x - y;
}
int Mul(int x, int y) {
  return x * y;
}
int Div(int x, int y) {
  return x / y;
}
void menu() {
  printf("*****************************************\n");
  printf("*********1.Add***************************\n");
  printf("*********2.Sub***************************\n");
  printf("*********3.Mul***************************\n");
  printf("*********4.Div***************************\n");
  printf("*********0.exit**************************\n");
  printf("*****************************************\n");
}
int main() {
  int x = 0;
  int y = 0;
  int input = 0;
  int ret = 0;
  do {
    menu();
    printf("请选择:> ");
    scanf("%d",&input);
    switch (input)
    {
    case 1:
      printf("请输入操作数:> ");
      scanf("%d %d", &x, &y);
      ret = Add(x, y);
      printf("%d\n", ret);
      break;
    case 2:
      printf("请输入操作数:> ");
      scanf("%d %d", &x, &y);
      ret = Sub(x, y);
      printf("%d\n", ret);
      break;
    case 3:
      printf("请输入操作数:> ");
      scanf("%d %d", &x, &y);
      ret = Mul(x, y);
      printf("%d\n", ret);
      break;
    case 4:
      printf("请输入操作数:> ");
      scanf("%d %d", &x, &y);
      ret = Div(x, y);
      printf("%d\n", ret);
      break;
    case 0:
      printf("退出程序\n");
      break;
    default:
      printf("输入错误,请重新输入\n");
      break;
    }
  } while (input);
  return 0;
}

使⽤函数指针数组的实现(转移表)

前面,我们使用调用函数的方式,来实现计算器的基本功能。

但是,在一些牛逼的计算器中,实现的功能会更多,不仅实现加减乘除,还能实现位运算等。

那么,我们还是依然去调用函数吗?switch语句也会越来越长

会不会有点麻烦啦?

于是,我们需要在上面的基础上进行更改。

简化代码:

# define _CRT_SECURE_NO_WARNINGS
# define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int Add(int x, int y) {
  return x + y;
}
int Sub(int x, int y) {
  return x - y;
}
int Mul(int x, int y) {
  return x * y;
}
int Div(int x, int y) {
  return x / y;
}
void menu() {
  printf("*****************************************\n");
  printf("*********1.Add***************************\n");
  printf("*********2.Sub***************************\n");
  printf("*********3.Mul***************************\n");
  printf("*********4.Div***************************\n");
  printf("*********0.exit**************************\n");
  printf("*****************************************\n");
}
int main() {
  int x = 0;
  int y = 0;
  int input = 0;
  int ret = 0;
  //函数指针数组
  int(*pfArr[])(int x,int y) = { 0,Add,Sub,Mul,Div };   //转移表
                             //  0  1   2   3   4
  do {
    menu();
    printf("请选择:> ");
    scanf("%d", &input);
    if (input >= 1 && input <= 4) {
      printf("请输入操作数:>");
      scanf("%d %d", &x, &y);
      ret =(*pfArr[input])(x, y);
      printf("%d\n", ret);
    }
    else if (input == 0) {
      printf("退出程序\n");
    }
    else {
      printf("输入错误,重新输入\n");
    }
  } while (input);
  return 0;
}


目录
相关文章
|
移动开发 前端开发 JavaScript
在线考试系统设计+源码
在线考试系统设计+源码
558 0
在线考试系统设计+源码
|
监控 Windows
Windows下一个简单的日志系统的C代码实现
       问题描述        实现一个简单的基于Windows的日志系统,要求写入日志文件的内容的样式如下:        [时间]+[文件名]+[日志等级]+日志具体内容        如:        [2015.
1304 0
|
10天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
9天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
401 130
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
3天前
|
存储 安全 前端开发
如何将加密和解密函数应用到实际项目中?
如何将加密和解密函数应用到实际项目中?
197 138
|
9天前
|
人工智能 Java API
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
本文介绍AI大模型的核心概念、分类及开发者学习路径,重点讲解如何选择与接入大模型。项目基于Spring Boot,使用阿里云灵积模型(Qwen-Plus),对比SDK、HTTP、Spring AI和LangChain4j四种接入方式,助力开发者高效构建AI应用。
376 122
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
|
3天前
|
存储 JSON 安全
加密和解密函数的具体实现代码
加密和解密函数的具体实现代码
195 136
|
21天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1347 8