Part 1
- 第一部分的parent非常好写,按照题目要求,如果parent是null不返回null,而是返回一个zero-parameter的new SibTreeNode就行。
Part 2
- InsertChild的话,就考虑比较多的情况即可,这次lab作业比较仓促,没有太多时间优化代码,只能想到一种case就往上加,所以导致代码比较臃肿。考虑情况如下:c小于1的时候于c等于1相同,还得考虑加进去的是第一个child的情况。最后一个的情况,以及中间位置的情况。
Part 3
- Remove Leaf相对好写,也是,考虑多种情况,如remove root,remove的正是第一个child。
- 还要会寻找this的前一个sibling,这就需要返回parent后,再顺着first child一个一个找。总之和linked list有点像,一个连一个的。