当前位置: 首页 > news >正文

中国新冠疫苗接种率树枝seo

中国新冠疫苗接种率,树枝seo,专业设计软件,wordpress建论坛二叉树存储 普通做法,二叉树一个节点包括结点的数值以及指向左右子节点的指针 在class Node中 def __init__(self,s,lNone,rNone):self.valNoneself.llself.rr 在竞赛中,我们往往使用静态数组实现二叉树,定义一个大小为N的静态结构体数组…

二叉树存储

普通做法,二叉树一个节点包括结点的数值以及指向左右子节点的指针

在class Node中

def __init__(self,s,l=None,r=None):self.val=Noneself.l=lself.r=r

在竞赛中,我们往往使用静态数组实现二叉树,定义一个大小为N的静态结构体数组,使用其来存储一棵二叉树。

#定义静态数组
tree=['']*10000
#根节点
tree[1]
#结点tree[p]的左子节点
tree[2*p]
#结点tree[p]的右子节点
tree[2*p+1]

使用静态数组时,对应的tree假如不是满二叉树,则应该使用-1或者0填补空缺,这样tree对应的静态数组即可使用于任何一个二叉树。 

三种遍历方式

先序遍历

EBADCGFIH

def preorder(p):print(tree[p],end='')if tree[2*p]!='':postorder(2*p)if tree[2*p+1]!='':postorder(2*p+1)

按照父、左儿子、右儿子的顺序进行访问

中序遍历

ABCDEFGHI

def inorder(p):if tree[2*p]!='': inorder(2*p)print(tree[p],end='')if tree[2*p+1]!='': inorder(2*p+1)

按照左儿子 、父、右儿子的顺序进行访问

后序遍历

ACDBFHIGE

def postorder(p):if tree[2*p] != '':    postorder(2*p)if tree[2*p+1] !='':   postorder(2*p+1)print(tree[p],end='')

按照左儿子、右儿子、父的顺序访问。

根据中序遍历和后序遍历可以确定一棵树。

由先序遍历和后序遍历不能确定一棵树。

FBI树

题目描述

我们可以把由 “0” 和 “1” 组成的字符串分为三类:全 “0” 串称为 B 串,全 “1” 串称为 I 串,既含 “0” 又含 “1” 的串则称为 F 串。

FBI树是一种二叉树,它的结点类型也包括 F 结点,B 结点和 I 结点三种。由一个长度为 2^N 的 “01” 串 S 可以构造出一棵 FBI 树 T,递归的构造方法如下:

  1. T 的根结点为 R,其类型与串 S 的类型相同;

  2. 若串 S 的长度大于 1,将串 S 从中间分开,分为等长的左右子串 S1 和 S2 ;由左子串 S1 构造 R 的左子树 T1,由右子串 S2 构造 R 的右子树 T2。

现在给定一个长度为 2^N 的 “01” 串,请用上述构造方法构造出一棵FBI树,并输出它的后序遍历序列。

输入描述

第一行是一个整数 N(0≤N≤10)N(0≤N≤10)。

第二行是一个长度为 2^N 的 “01” 串。

输出描述

输出一个字符串,即 FBI 树的后序遍历序列。

输入输出样例

示例 1

3  
10001011

输出

IBFBBBFIBFIIIFF

 错误做法

class node:def __init__(self,s,l=None,r=None):self.val=Noneself.l=l;self.r=rif '0' in s and 'l' in s:self.val='F'elif '0' in s:self.val='B'else:self.val='I'def build(s):if len(s)==1:return node(s)if len(s)==0:return Noneroot=node(s,build(s[:len(s)//2]),build(s[len(s)//2:]))return rootdef postorder(root):if root:postorder(root.l)postorder(root.r)print(root.val,end='')else:returnn=int(input())
s=input()
root=build(s)
postorder(root)

此外,可以使用一维数组存储二叉树.

def build(p,L,R):if L==R:if s[R]=='1':tree[p]='I'else:tree[p]='B'returnmid=(L+R)//2build(2*p,L,mid)build(2*p+1,mid+1,R)if tree[2*p]=='B' and tree[2*p+1]=='B':tree[p]='B'elif tree[2*p]=='I' and tree[2*p+1]=='I':tree[p]='I'else:tree[p]='F'def postorder(p):if tree[2*p]!='':postorder(2*p)if tree[2*p+1]!='':postorder(2*p+1)print(tree[p],end='')n=int(input())
s=[0]+list(input())
tree=['']*4400
build(1,1,len(s)-1)
postorder(1)

http://www.shuangfujiaoyu.com/news/60039.html

相关文章:

  • 网站推广和seo网站生成器
  • 盗图来做网站北京企业网站推广哪家公司好
  • jsp动态网站开发考试题营销模式和营销策略
  • 浦东网站建设公司在线咨询
  • 做网站的文案怎么写seo搜索引擎优化哪家好
  • 网站建设色彩设计有什么用广点通
  • 没有网站服务器空间如何用ftpseo搜索推广
  • 如何建设社区网站网站推广优化排名seo
  • 东莞网站优化公司搜索引擎费用
  • 广州网站建设clov5r网站推广引流最快方法
  • 党政机关门户网站建设网站排名优化价格
  • 重庆电商网站建设制作一个网站需要多少费用
  • 怎么做扒代码网站百度搜索排名服务
  • 成都网站建设哪儿济南兴田德润怎么联系郑州制作网站公司
  • 网站建设的特点友情链接有用吗
  • 石家庄有哪些公司可以做网站微信群推广网站
  • 微网站制作十大免费网站推广入口
  • 华亭县门户网站最简短的培训心得
  • 山西做网站的企业百度竞价排名服务
  • 谎称在赌博网站做维护seo是什么意思的缩写
  • 宝鸡网站建设排行榜google推广方式和手段有哪些
  • 河南seo公司企业网站seo案例分析
  • 武汉网站快速排名提升seo百度站长工具查询
  • 美发网站带手机版品牌运营具体做什么
  • 建设一个商城式网站可以吗广州今天刚刚发生的重大新闻
  • b2c商城网站营销方案seo和sem分别是什么
  • 合肥房产网58同城西安seo优化工作室
  • 怎么打帮人 做网站开发的广告凡科网建站系统源码
  • 邯郸做网站价格优质友情链接
  • 如何做网站大图片免费网站开发平台