利用栈实现二叉树的前序遍历——C语言

首先我们定义以下二叉树的数据结构,通过结构体定义,代码如下:

struct Tree {
	int n;
	struct Tree* p;
	struct Tree* left;
	struct Tree* right;
};

struct BinaryTree {
	struct Tree* root;
};

为了完成深度优先搜索,我们需要借助于栈结构。包括压栈,出栈操作,基于数组实现。代码如下:

struct Stack {
	struct Tree a[20];
	int maxIndex;      //栈顶元素的下标,初始为-1
};
void push(struct Stack* s, struct Tree node) {
	if (s->maxIndex >= 19) {
		printf("Stack has no room!\n");
		return;
	}
	s->maxIndex++;
	s->a[s->maxIndex] = node;
}
struct Tree pop(struct Stack* s) {
	if (s->maxIndex < 0) {
		printf("Stack has no node!\n");
		exit(0);
	}
	s->maxIndex--;
	return s->a[s->maxIndex + 1];
}

接下来便是对树进行遍历的代码,我们采用深度优先搜索:先将根节点压入栈中。对栈中的节点循环进行以下操作:每次将栈顶元素出栈,打印该元素内容,并且将其右子数根节点,左子树根节点(如果有)分别压栈。循环以下操作,直到

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值