【考研数据结构代码题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;
}
相关推荐
kupeThinkPoem23 分钟前
计算机算法导论第三版算法视频讲解
数据结构·算法
Solar20251 小时前
企业数据采集系统的架构设计与工程实践:从数据孤岛到智能决策的破局之道
数据结构
H_z___4 小时前
Codeforces Round 1070 (Div. 2) A~D F
数据结构·算法
如竟没有火炬6 小时前
四数相加贰——哈希表
数据结构·python·算法·leetcode·散列表
仰泳的熊猫6 小时前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
不穿格子的程序员6 小时前
从零开始学算法——链表篇3:合并两个有序链表 + 两数相加
数据结构·算法·链表·dummy
子一!!7 小时前
数据结构==LRU Cache ==
数据结构
hweiyu007 小时前
数据结构:邻接矩阵
数据结构
CS创新实验室8 小时前
计算机考研408【操作系统】核心知识点总结
java·linux·考研·计算机·操作系统·408
Fine姐8 小时前
数据结构01——栈
数据结构