python 二叉树计算器
例子:计算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 二叉树计算器的更多相关文章
- 从零开始学习PYTHON3讲义(二)把Python当做计算器
		<从零开始PYTHON3>第二讲 上一讲我们说过了如何启动Python IDLE集成开发学习环境,macOS/Linux都可以在命令行执行idle3.Windows则从开始菜单中去寻找ID ... 
- python实现计算器
		计算器功能 实现优先级解析,加减乘除四则运算 自定义小数位精度 实现思想: 先找到最里层括号,根据乘除,加减优先级,调用写好的乘除.加减运算函数算出括号内总值,再将原括号式用所得值替换,此过程循环进行 ... 
- python之计算器(第四天)
		作业: 使用正则表达式和递归实现计算器功能. 实现: 1.实现带括号的计算 2.实现指数.加减乘除求余等功能 一.实例说明: 本实例自己写了个版本,但依旧存在一点bug,例:-2-2等计算问题,故最后 ... 
- 利用PYTHON设计计算器功能
		通过利用PYTHON 设计处理计算器的功能如: 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 ))- (-4*3 ... 
- Python科学计算器(计算器)
		说明 该计算器主要是为了练习正则表达式以及python基础所写:代码比较low! 运行过程 请输入你的计算公式, 计算器会将计算结果输出到屏幕上(此处会打印步骤); 退出(exit/quit) MyC ... 
- Python数学运算入门把Python当作计算器
		让我们尝试一些简单的 Python 命令.启动解释器,等待界面中的提示符,>>> (这应该花不了多少时间). 3.1.1. 数字 解释器就像一个简单的计算器一样:你可以在里面输入一个 ... 
- python之计算器
		开发一个简单的python计算器 1.实现加减乘除及拓号优先级解析 2.用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * ... 
- [IT学习]转载python 项目 计算器
		这个是从网上搜到的Python小项目之计算器(原文地址:http://www.2cto.com/kf/201402/279637.html).但该段代码估计是Python 2 写的. 如果你使用的程序 ... 
- Python --- 二叉树的层序建立与三种遍历
		二叉树(Binary Tree)时数据结构中一个非常重要的结构,其具有....(此处省略好多字)....等的优良特点. 之前在刷LeetCode的时候把有关树的题目全部跳过了,(ORZ:我这种连数据结 ... 
随机推荐
- lua-redis-parser module
			https://github.com/openresty/lua-redis-parser 此模块主要是处理redis请求和响应的. local parser = require "redi ... 
- win10操作系统系统,小米路由器,小米3 的问题
			注意 , 置顶 单独一篇 : { win10 局域网共享 小米路由器,操作盘太卡 } 开发中用专业版 , 别用家庭版 比如有远程桌面程序 和 HV 虚拟机 查看激活信息 和 是不是永久激活 参考 h ... 
- Rsa2验签报错【java.security.SignatureException: Signature length not correct】的解决办法
			在进行RSA2进行验签的时候,报了以下错误: java.security.SignatureException: Signature length not correct: got 344 but w ... 
- Hive动态分区 参数配置及语法
			Hive本身是不支持动态分区的.. 但动态分区是真的方便啊..不然手动维护要累死..按日期甚至小时来分区时动辄就好几千上万的分区..手动到哪一年去..? 想要用动态分区要先做一些设置来修改默认的配置. ... 
- vue中$nextTick的用法
			简介 vue是非常流行的框架,他结合了angular和react的优点,从而形成了一个轻量级的易上手的具有双向数据绑定特性的mvvm框架.本人比较喜欢用之.在我们用vue时,我们经常用到一个方法是th ... 
- Robot Framework自动化测试三(selenium API)
			Robot Framework Selenium API 说明: 此文档只是将最常用的UI 操作列出.更多方法请查找selenium2Library 关键字库. 一.浏览器驱动 通过不同的浏览器 ... 
- Oracle 12c心得
			1.重新启动Listener后,远程客户端登录不了,只能全新启动Oralce服务才能正常,经分析,用Net Manager增加一个服务器的IP地址的监听. 执行 net start 监听服务名 再远程 ... 
- ASP.NET Core中使用自定义路由
			上一篇文章<ASP.NET Core中使用默认MVC路由>提到了如何使用默认的MVC路由配置,通过这个配置,我们就可以把请求路由到Controller和Action,通常情况下我们使用默认 ... 
- MySQL wait_timeout参数设置与网上常见错误小纠
			discard connection com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link fail ... 
- Grunt:任务自动管理工具(收藏+转载)
			原文:http://javascript.ruanyifeng.com/tool/grunt.html 安装 命令脚本文件Gruntfile.js Gruntfile.js实例:grunt-contr ... 
