例子:计算1+2+3+4的值

代码:

class Buffer(object):
"""字符串处理函数""" def __init__(self, str_value):
self._str_value = str_value
self._off_set = def peek(self):
if self._off_set >= len(self._str_value):
return None
else:
return self._str_value[self._off_set] def advance(self):
self._off_set += class Token(object):
"""定义节点类型,{int,2}{ope,+}""" def consum(self, buffer):
pass class TokenInt(Token):
"""整数节点类型{int,2}""" def consum(self, buffer):
accu = ""
while True:
ch = buffer.peek()
if ch is None or ch not in "":
break
else:
accu += ch
buffer.advance()
if accu != "":
return "int", int(accu)
else:
return None class TokenOperator(Token):
"""操作符接点类型,返回{ope,+}""" def consum(self, buffer):
ch = buffer.peek()
if ch is not None and ch in "+-":
buffer.advance()
return "ope", ch
else:
return None class Node(object):
"""节点"""
pass class NodeInt(Node):
"""整数节点""" def __init__(self, value):
self.value = value class NodeOpe(Node):
"""加减节点""" def __init__(self, kind):
self.kind = kind
self.left = None
self.right = None def get_tokens(string):
"""根据string获取节点类型数组"""
buffer = Buffer(string)
tk_int = TokenInt()
tk_ope = TokenOperator()
tokens = [] while buffer.peek():
token = None
for tk in (tk_int, tk_ope):
token = tk.consum(buffer)
if token:
tokens.append(token)
break
if not token:
raise ValueError("Error in syntax")
return tokens def parse(tokens):
"""将tokens生成二叉树"""
# 判断第一个是不是数字
if tokens[][] != 'int':
raise ValueError('Error in syntax')
# 新建第一个节点
node = NodeInt(tokens[][])
# 下一个节点
node_next = None
# 节点类型
node_type = tokens[][]
for token in tokens[:]:
# 判断节点类型是否一致
if token[] == node_type:
raise ValueError("error in syntax")
node_type = token[]
# 判断是什么操作符
# 如果是符号
if token[] == 'ope':
node_next = NodeOpe(token[])
node_next.left = node
if token[] == 'int':
node_next.right = NodeInt(token[])
node = node_next
return node def calculate(node):
"""迭代求值"""
if isinstance(node.left, NodeOpe):
left_value = calculate(node.left)
else:
left_value = node.left.value if node.kind == '-':
return left_value - node.right.value
elif node.kind == '+':
return left_value + node.right.value
else:
raise ValueError('Error in syntax') def evalute(node):
"""判断是否只有一个数值"""
if isinstance(node, NodeInt):
return node.value
else:
return calculate(node) if __name__ == '__main__':
input_str = input("input:")
tokens = get_tokens(input_str)
node = parse(tokens)
print("value is {}".format(evalute(node)))

python 二叉树计算器的更多相关文章

  1. 从零开始学习PYTHON3讲义(二)把Python当做计算器

    <从零开始PYTHON3>第二讲 上一讲我们说过了如何启动Python IDLE集成开发学习环境,macOS/Linux都可以在命令行执行idle3.Windows则从开始菜单中去寻找ID ...

  2. python实现计算器

    计算器功能 实现优先级解析,加减乘除四则运算 自定义小数位精度 实现思想: 先找到最里层括号,根据乘除,加减优先级,调用写好的乘除.加减运算函数算出括号内总值,再将原括号式用所得值替换,此过程循环进行 ...

  3. python之计算器(第四天)

    作业: 使用正则表达式和递归实现计算器功能. 实现: 1.实现带括号的计算 2.实现指数.加减乘除求余等功能 一.实例说明: 本实例自己写了个版本,但依旧存在一点bug,例:-2-2等计算问题,故最后 ...

  4. 利用PYTHON设计计算器功能

    通过利用PYTHON 设计处理计算器的功能如: 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 ))- (-4*3 ...

  5. Python科学计算器(计算器)

    说明 该计算器主要是为了练习正则表达式以及python基础所写:代码比较low! 运行过程 请输入你的计算公式, 计算器会将计算结果输出到屏幕上(此处会打印步骤); 退出(exit/quit) MyC ...

  6. Python数学运算入门把Python当作计算器

    让我们尝试一些简单的 Python 命令.启动解释器,等待界面中的提示符,>>> (这应该花不了多少时间). 3.1.1. 数字 解释器就像一个简单的计算器一样:你可以在里面输入一个 ...

  7. python之计算器

    开发一个简单的python计算器 1.实现加减乘除及拓号优先级解析 2.用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * ...

  8. [IT学习]转载python 项目 计算器

    这个是从网上搜到的Python小项目之计算器(原文地址:http://www.2cto.com/kf/201402/279637.html).但该段代码估计是Python 2 写的. 如果你使用的程序 ...

  9. Python --- 二叉树的层序建立与三种遍历

    二叉树(Binary Tree)时数据结构中一个非常重要的结构,其具有....(此处省略好多字)....等的优良特点. 之前在刷LeetCode的时候把有关树的题目全部跳过了,(ORZ:我这种连数据结 ...

随机推荐

  1. python 实现dns 解析发送接收报文

    http://www.qingruxu.com/code/python/851.html https://tools.ietf.org/html/rfc1035里面的图不一定正确,可以使用抓包软件来进 ...

  2. TomCat端口被占用问题

    TomCat在使用时,有时会爆出端口被占用的问题 解决方法: 1.快捷键win+R,输入cmd,点击回车后再输入netstat -ano|findstr 8005 注:什么端口被占用就输入什么端口号 ...

  3. C++中函数调用时的三种参数传递方式

    在C++中,参数传递的方式是“实虚结合”. 按值传递(pass by value) 地址传递(pass by pointer) 引用传递(pass by reference) 按值传递的过程为:首先计 ...

  4. Oracle rownum

    本问参考自Oracle中ROWNUM的使用技巧.纯属读书笔记,用于加深记忆 rownum是oracle中的一种伪列,它会根据返回的记录生成一个序列化的数字,利用rownum,我们可以得到一些原先难以得 ...

  5. Oracle Schema

    1.这是Schema的definition: A schema is a collection of database objects (used by a user.) Schema objects ...

  6. Jmeter断言实例—响应断言

    断言有很多种,最最最常用的一种就是响应断言,目前我用的最多是这一种,下面列举一个运用响应断言的实例 对相应的请求添加断言 **Main sample and sub-samples:断言应用于主采样器 ...

  7. 新时代运维重器 Tencent Hub 最佳实践——云+未来峰会开发者专场回顾

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 演讲者:邹辉 腾讯云 PaaS 产品总监 背景:5月23-24日,以"焕启"为主题的腾讯"云+未来" ...

  8. CentOS 7下使用yum安装MySQL5.7

    1.卸载 1.1先停掉mysql进程,没有安装过的可以直接跳过 pkill - mysqld rpm -qa|grep -i mysql 1.2用命令 yum -y remove -.el7.x86_ ...

  9. Scrum 冲刺博客第一篇

    一.各个成员在 Alpha 阶段认领的任务 成员 Alpha 阶段认领的任务 黄腾龙 主要功能模块代码开发 叶城龙 部分模块代码开发,博客撰写 李心宇 代码测试,博客撰写 余腾鑫 界面设计,博客撰写 ...

  10. [转]How to use an Area in ASP.NET Core

    本文转自:http://stackoverflow.com/questions/36535511/how-to-use-an-area-in-asp-net-core Q: How does one ...