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:我这种连数据结 ...
随机推荐
- Linux and Shell 实用命令
-name '*.jar' -printf '%p:' ### 查看CPU使用率 mpstat -P ALL
- cookie session token详解
cookie session token详解 转自:http://www.cnblogs.com/moyand/ 发展史 1.很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, ...
- post调试postman
载地址:https://www.getpostman.com/ 教程地址:http://www.cnblogs.com/s380774061/p/4624326.html
- 制作web安装程序
出处:http://www/i-blog.cn/u/chenli/archives/2006/8.html 本文参考http://blog.csdn.net/libra1983/archive/200 ...
- (转)[InnoDB系列] -- SHOW INNODB STATUS 探秘
原文:http://imysql.cn/2008_05_22_walk_through_show_innodb_status 很多人让我来阐述一下 SHOW INNODB STATUS 的输出信息, ...
- Java学习之路(二):Java中的方法
Java中的方法 概念: 为什么要有方法: 提高代码的复用性 什么是方法: 完成特定功能的代码块 格式: 修饰符 返回值类型 方法名(参数){ 方法体语句: return 返回值: } 1.修饰符:例 ...
- Python学习--猫眼电影TOP100榜单抓取
import requests import re import json import time def get_one_page(url): headers={'User-Agent':'Mozi ...
- selenium+Python(Js处理日历控件)
日历控件是web网站上经常会遇到的一个场景,有些输入框是可以直接输入日期的,有些不能,以我们经常抢票的12306网站为例,详细讲解如何解决日历控件为readonly属性的问题. 基本思路:先用js去掉 ...
- unity状态机实现
刚看了浅墨大神的文章让我对状态机有了进一步的理解 具体实现见装载的状态机文章 首先得有个总状态HeroineBaseState接口,其里面的方法主要是与行为相关的方法,让继承此接口的类来实现的 具体的 ...
- C 标准库 - string.h
C 标准库 - string.h This header file defines several functions to manipulate C strings and arrays. stri ...