数据结构之树(五)——森林与二叉树的转换

森林转换成二叉树

  • 转换方法:
    • 1.将各棵树分别转换成二叉树。
    • 2.将将每棵树的根结点用线相连。
    • 3.以第一棵树的根结点为二叉树的根,再以根结点为轴心,顺时针旋转,形成二叉树型结构。

即,树变二叉根相连

  • 转换过程: 将下图的森林转换成二叉树
    在这里插入图片描述
    • 1.将每棵树都变成二叉树。
      在这里插入图片描述
    • 2.将每棵树的根都连接在一起。
      在这里插入图片描述
    • 3.只留第一个根(A),其余根绕A旋转,形成二叉树。
      在这里插入图片描述



二叉树转换成森林

  • 转换方法:
    • 1.抹线:将二叉树中根结点与其右孩子连线,及沿右分支搜索到的所有右孩子间连线全部抹掉,使之变成孤立的二叉树。
    • 2.还原:将孤立的二叉树还原成树。

即,去掉全部右孩线,孤立二叉再还原

  • 转换过程: 将下图的二叉树转换成森林
    在这里插入图片描述
    • 1.去掉与根结点相连的全部右孩线,使之成为孤立的树。
      在这里插入图片描述
      在这里插入图片描述
    • 2.将孤立之后的多棵二叉树还原成树。
      在这里插入图片描述
  • 7
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值