创建孩子兄弟链表的树c语言,树的孩子兄弟链表实现

树的孩子兄弟链表存储结构,采用两条链分别连接孩子和兄弟结点。其中,child指向该结点的第一个孩子结点,sibling指向该结点的下一个兄弟结点。

public class Tree {

private TreeNode root;

private class TreeNode{//树的孩子兄弟链表结点类

T data;

TreeNode child,sibling;//分别指向孩子、兄弟结点

public TreeNode() {

}

public TreeNode(T data){

this(data,null,null);

}

public TreeNode(T data,TreeNode child,TreeNode sibling){

this.data = data;

this.child = child;

this.sibling = sibling;

}

}

public Tree() {

}

public boolean isEmpty(){

return this.root == null;

}

//返回p结点最后一个兄弟结点

public TreeNode getLastSibling(TreeNode p){

if(p==null || p.sibling==null)

return null;

while(p.sibling!=null)

p = p.sibling;

return p;

}

//返回p结点的最后一个孩子

public TreeNode getLastChild(TreeNode p){

if(p==null || p.child==null)

return null;

p = p.child;

while(p.sibling!=null)

p = p.sibling;

return p;

}

//插入x作为根结点

public void insertRoot(T x){

this.root = new TreeNode(x,this.root,null);

}

//插入x作为p结点的最后一个兄弟结点

public TreeNode insertLastSibling(TreeNode p,T x){

if(p==null)

return null;

while(p.sibling!=null)

p = p.sibling;

p.sibling = new TreeNode(x);

return p.sibling;

}

//插入x作为p结点的最后一个孩子结点

public TreeNode insertLastChild(TreeNode p,T x){

if(p==null)

return null;

if(p.child==null){

p.child = new TreeNode(x);

return p.child;

}

else

return insertLastSibling(p.child,x);

}

//先根次序遍历树并返回树的横向凹入表示字符串

public String toString(){

return toString(root,"");

}

//tab表示缩进量

private String toString(TreeNode p,String tab){

if(p==null)

return "";

return tab+p.data.toString()+"\n"+toString(p.child,tab+"\t")+toString(p.sibling,tab);//递归调用

}

public Tree make(){

Tree tree = new Tree();

tree.root = new TreeNode("中国");

tree.insertLastChild(tree.root, "北京市");

tree.insertLastChild(tree.root, "上海市");

TreeNode js = tree.insertLastChild(tree.root, "江苏省");

tree.insertLastChild(js, "南京市");

tree.insertLastChild(js, "苏州市");

TreeNode korea = tree.insertLastSibling(tree.root, "韩国");

tree.insertLastChild(korea,"首尔");

return tree;

}

public static void main(String[] args) {

Tree t = new Tree();

System.out.println(t.make());

}

}

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值