【考研数据结构代码题5】二叉树搜索指定关键字和其父亲结点

题目:已知一棵二叉树已经存在,二叉树的结点有三个域,分别是左右孩子指针域与数据域,且数据域为字符型,规定指针bt指向根结点。给定一个字符ch,请编写程序实现查找二叉树中是否存在数据域为ch的结点?若存在再找出该结点的双亲结点

难度:★★★

cpp 复制代码
#include<stdio.h>
#include<stdlib.h>
//二叉树存储结构
typedef struct node{
	char key;//数据域
	struct node *left,*right;//左右孩子指针域 
}BiNode;
//递归查找指定关键字结点
void find(BiNode *T,char target,BiNode *parent){
	if(T){
		int left_s,right_s;
		//如果当前结点就是要找的关键字结点,则输出其父节点关键字
		if(T->key==target){
			if(!parent)printf("NULL");
			else printf("%c",parent->key);
		}
		//递归搜索 
		if(T->left)  find(T->left,target,T);
		if(T->right) find(T->right,target,T);
	}
} 

int main(){
	char target;//目标关键字符
	scanf("%c",&target);
	find(bt,target,NULL);//bt为题目已知条件,指向该树的根节点
	return 0;
}
相关推荐
宇木灵15 小时前
考研数学-高中数学-反三角函数与特殊函数day3
笔记·考研·数学·函数
蚊子码农15 小时前
算法题解记录--239滑动窗口最大值
数据结构·算法
额,不知道写啥。17 小时前
HAO的线段树(中(上))
数据结构·c++·算法
blackicexs18 小时前
第五周第七天
数据结构·算法
夏乌_Wx18 小时前
反转链表:三种实现思路与细节梳理
数据结构·链表
紫陌涵光20 小时前
108.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
载数而行52020 小时前
算法系列2之最短路径
c语言·数据结构·c++·算法·贪心算法
fu的博客20 小时前
【数据结构10】满/完全二叉树、顺序/链式存储
数据结构·
逆境不可逃21 小时前
【除夕篇】LeetCode 热题 100 之 189.轮转数组
java·数据结构·算法·链表
wefg11 天前
【算法】倍增思想(快速幂)
数据结构·c++·算法