数据结构——查找算法的实现与分析(二叉排序树)

课程名称:数据结构

 

实验项目名称:查找算法的实现与分析

 

实验目的:

1.掌握二叉排序树的创建及查找算法(递归和非递归均可)。

实验要求:

1、    创建一棵二叉排序树,并实现对该二叉排序树的查找算法。

实验过程:

1、    输入一数据序列,根据输入的数据序列创建一棵二叉排序树(二叉链表);

2、    在已创建的二叉排序树中查找“37”和“66”两个结点,并给出相应的查询结果。

实验报告中给出创建二叉排序树和二叉排序树的查找算法代码。

实验结果:

1、输入数据序列:45,24,53,12,37,93。

2、输出二叉排序树的中序遍历序列:12,24,37,45,53,93;

3、

输入要查找的数据:37, 输出查找的结果:该结点已找到。

输入要查找的数据:93, 输出查找的结果:该结点未找到。

实验分析:

1.对二叉排序树的查找进行性能分析,计算其ASL;

2.列举调试运行过程中出现的错误并分析原因。

要求:

(1) 程序要添加适当的注释,程序的书写要采用缩进格式

(2) 程序要具在一定的健壮性,即当输入数据非法时,程序也能适当地做出反应。

(3) 程序要做到界面友好,在程序运行时用户可以根据相应的提示信息进行操作。

 

#include<bits/stdc++.h>
using namespace std;
#define KeyType int
#define InfoType int
#define ENDFLAG 0

typedef struct{
    KeyType key;
    InfoType otherinfo;
}ElemType;
typedef struct BSTNode{
    ElemType data;
    struct BSTNode *lchild, *rchild;
}BSTNode, *BSTree;

ElemType e;
BSTree S, T;
BSTree SearchBST(BSTree T, KeyType key){
    if((!T) || key == T->data.key)  return T;
    else if(key < T->data.key) return SearchBST(T->lchild, key);
    else return SearchBST(T->rchild, key);
}
void InsertBST(BSTree &T, ElemType e){
    if(!T){
        S = new BSTNode;
        S->data = e;
        S->lchild = S->rchild = NULL;
        T = S;
    }
    else if(e.key < T->data.key)
        InsertBST(T->lchild,e);
    else if(e.key > T->data.key)
        InsertBST(T->rchild,e);
}
void CreatBST(BSTree &T){
    T = NULL;
    cin >> e.key;
    while(e.key != ENDFLAG){
        InsertBST(T, e);
        cin >> e.key;
    }
}
void InOrderTraverse(BSTree T){
	if(T){
		InOrderTraverse(T->lchild);
		cout << T->data.key << " ";
		InOrderTraverse(T->rchild);
	}
}
int main(){
	cout << "请输入关键字" << endl;
	CreatBST(T);
	cout << "二叉排序树的中序遍历序列:" << endl;
	InOrderTraverse(T);
	int n;
	cout << "输入要查找的数据:" << endl;
	while(scanf("%d",&n) != EOF && n){
		if(SearchBST(T, n))
			cout << "输出查找的结果:该结点已找到。" << endl;
		else
			cout << "输出查找的结果:该结点未找到。" << endl;
	}
    return 0;
}
/*
45 24 53 12 37 93 0
*/

 

  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值