Fork me on GitHub

(QT) C++学习之路之——计算器的实现

(QT) C++学习之路之——计算器的实现

在学校一直学习的是 Android 应用开发,入职后公司要求转C++(QT) 开发,嫁鸡随鸡。同时公司给新员工有几门培训课程,而每门课都有作业,这篇文章便是“数据结构”这门课的作业说明。

PS:控制台的计算器实现,C++代码,可进行加减乘除四则运算,支持负数小数运算。


本计算器的主要特点为:

  1. 自定义栈和单链表。
  2. 提供顶层计算接口,由实现类完成具体计算方法,易扩展。
  3. 利用简单工厂模式实现计算器的计算部分。
  4. 通过栈的特性进行四则运算表达式的括号匹配。
  5. 抽取Check类,完成输入表达式的正确性校验,复用性强。

本计算器的主要思想过程为:

  • 首先对输入的表达式进行非法校验,如果输入非法,提示用户重新输入。
  • 然后将中缀表达式转化为后缀表达式,并对负号和减号进行区分,消除括号,只保留数字和运算符。
  • 其次对后缀表达式中的小数点、非个位数进行处理,转化为数字。
  • 再次依次出栈根据不同的运算符进行计算。
  • 最后得出结果并打印。

JSQ_C++.cpp

本文件为主函数入口,通过调用计算器的run方法启动计算器。

JSQ.cpp

本文件封装了计算器的核心算法思想,提供三个方法,

  • mid2Behind方法:将输入的中缀表达式转换为后缀表达式(逆波兰表达式)。
  • readNumber方法:将后缀表达式中的字符处理为数字(包含小数点和非个位数字处理)。
  • caculate 方法:利用工厂方法产出计算结果。

OptionerFactory.cpp

本文件是操作符的生产类,根据传入参数生产不同的操作符对象。

Check.cpp

本文件只暴露一个public的check方法,供外部调用,进行输入非法校验。
其余还包含4个或更多的private方法,实现具体的判断逻辑,返回结果给public的check方法。

Util.cpp

本文件提供一系列的static方法,无关对象,只可访问,不可修改,任何人可以调用。
具体实现是一些常见的工具类。

IOperation.h

本文件是操作符的上层接口,只提供一个getResult方法,由加减乘除实现类去实现。

ADD.cpp SUB.cpp MUI.cpp DIV.cpp MOD.cpp

这五个文件为具体的运算类,实现了IOperation接口,进行具体的二元运算。

SLList.h

自定义的单链表,包含一个节点类和一个链表类,实现了链表常见的插入和删除操作。
由于属于模板类,因此声明和定义只能放到一个文件中。

StackDIY.h

使用SLList实现的栈,实现了常见的压栈、出栈、取栈顶元素等操作。