剑指leetcode—N叉树的前序遍历

题目描述:给定一个 N 叉树,返回其节点值的前序遍历。

例如,给定一个 3叉树 :

在这里插入图片描述

树的遍历有着四种遍历方式

  • 先序遍历
  • 后序遍历
  • 中序遍历
  • 层次遍历

这里的要求是使用先序遍历,同时要求使用迭代法,递归法的思想很简单

递归法

给出递归法的算法思想

void preorder(node * b)
{
	if(b!=null)
	{
	printf("%d",b->data);
	preorder(b->lchild);
	preorder(b->rchile);
	}
}




 

返回其前序遍历: [1,3,5,6,2,4]。

这里的树是通过链表实现的,但是题目中,每一个结点都有对应的子节点的列表,所以简化了题目。

/*
// Definition for a Node.
class Node {
    public int val;
    public List<Node> children;
    public Node() {}
    public Node(int _val) {
        val = _val;
    }
    public Node(int _val, List<Node> _children) {
        val = _val;
        children = _children;
    }
};
*/
class Solution {
   
    public List<Integer> preorder(Node root) {
       }
       }

解答如下

class Solution {
List <Integer> output=new ArrayList<Integer>();
   public List<Integer> preorder(Node root) {
   	if(root==null)
   	return output;
   	else
   		{
   	output.add(root.val);
   	for(int i=0;i<root.children.size();i++)
   		{
   	preorder(root.childred.get(i);
   		}
   		return output;
   	}

迭代法

使用一个栈来帮助我们得到前序遍历,需要保证栈顶的节点就是我们当前遍历到的节点。我们首先把根节点入栈,因为根节点是前序遍历中的第一个节点。随后每次我们从栈顶取出一个节点 u,它是我们当前遍历到的节点,并把 u 的所有子节点逆序推入栈中。例如 u 的子节点从左到右为 v1, v2, v3,那么推入栈的顺序应当为 v3, v2, v1,这样就保证了下一个遍历到的节点(即 u 的第一个子节点 v1)出现在栈顶的位置。

class Solution {
    public List<Integer> preorder(Node root) {
        LinkedList<Node> stack=new LinkedList<>();
        LinkedList<Integer> output=new LinkedList<>();
        if(root==null)
        return output;
    stack.add(root);
    while(!stack.isEmpty())
    {
        Node node=stack.pollLast();
        output.add(node.val);
        Collections.reverse(node.children);
        for(Node item:node.children){
            stack.add(item);
        }
    }
    return output;
    }
}

递归法,C语言实现

/**
 * Definition for a Node.
 * struct Node {
 *     int val;
 *     int numChildren;
 *     struct Node** children;
 * };
 */
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
 #define MAXSIZE 10000
 void pretraversa(struct Node * root,int * nums,int * i)
 {
     if(!root)
     return ;
     nums[(*i)]=root->val;
     (*i)++;
     for(int k=0;k<root->numChildren;k++)
     {
         pretraversa(root->children[k],nums,i);
     }
 }
int* preorder(struct Node* root, int* returnSize) {
    *returnSize=0;
    if(!root) return NULL;
    int i=0;
    int *nums=(int*)malloc(sizeof(int)*MAXSIZE);
    pretraversa(root,nums,&i);
    *returnSize=i;
    return nums;    
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Devin Dever

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值