数据结构电子课件、源代码07单元7 查找

数据结构电子课件、源代码07单元7 查找

ID:19182172

大小:4.27 MB

页数:16页

时间:2018-09-29

数据结构电子课件、源代码07单元7 查找_第1页
数据结构电子课件、源代码07单元7 查找_第2页
数据结构电子课件、源代码07单元7 查找_第3页
数据结构电子课件、源代码07单元7 查找_第4页
数据结构电子课件、源代码07单元7 查找_第5页
资源描述:

《数据结构电子课件、源代码07单元7 查找》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、《数据结构》课程-源代码软件技术专业国家教学资源库单元7查找源代码SC020201070011.源代码编号SC020201070012.源代码来源单元7查找7.2.13.问题描述顺序查找4.程序代码intSeqSearch(SeqlistR,KeyTypeK){//在顺序表R[1...n]中查找关键字为K的结点inti;R[0].key=K;//设置哨兵for(i=n;R[i].key!=K;i--);//从表后往前找returni;//若i为0,表示查找失败,否则R[i]是要找的结点}第16页共16页《数据结构》课程-源代码软件

2、技术专业国家教学资源库SC020201070021.源代码编号SC020201070022.源代码来源单元7查找7.2.23.问题描述二分查找4.程序代码intBinSearch(SeqListR,KeyTypeK){//在有序表R[1...n]中进行二分查找,成功时返回结点的位置,失败时返回零intlow=1,high=n,mid;//置当前查找区间的初值while(low<=high){//当前查找区间R[low...high]非空mid=(low+high)/2;if(R[mid].key==K)returnmid;//查找

3、成功返回if(R[mid].kdy>K)high=mid-1;//继续在R[low...mid-1]中查找elselow=mid+1;//继续在R[mid+1...high]中查找}return0;//当low>high时查找区间为空,查找失败}第16页共16页《数据结构》课程-源代码软件技术专业国家教学资源库SC020201070031.源代码编号SC020201070032.源代码来源单元7查找7.3.23.问题描述二叉排序树插入新结点递归算法4.程序代码voidInsertBSTR(BSTree*Tptr,KeyTypeke

4、y){if(!(*Tptr)){(*Tptr)=(BSTNode*)malloc(sizeof(BSTNode));if(*Tptr==NULL){puts("内存申请不成功!");return;}(*Tptr)->key=key;(*Tptr)->lchild=NULL;(*Tptr)->rchild=NULL;}else{if((*Tptr)->key==key)return;if(key<(*Tptr)->key)InsertBSTR(&(*Tptr)->lchild,key);elseInsertBSTR(&(*Tptr)

5、->rchild,key);}第16页共16页《数据结构》课程-源代码软件技术专业国家教学资源库}第16页共16页《数据结构》课程-源代码软件技术专业国家教学资源库SC020201070041.源代码编号SC020201070042.源代码来源单元7查找7.3.23.问题描述二叉排序树插入新结点的非递归算法4.程序代码voidInsertBST(BSTree*Tptr,KeyTypekey){//若二叉排序树*Tptr中没有关键字为key,则插入,否则直接返回BSTNode*f,*p=*Tptr;//p的初值指向根结点while(

6、p){//查找插入位置if(p->key==key)return;//树中已有key,无须插入f=p;//f保存当前查找的结点p=(keykey)?p->lchild:p->rchild;/*若keykey,则在左子树中查找,否则在右子树中查找*/}p=(BSTNode*)malloc(sizeof(BSTNode));if(p==NULL){puts("内存申请不成功!");return;}p->key=key;p->lchild=p->rchild=NULL;//生成新结点if(*Tptr==NULL)//原树

7、为空*Tptr=p;//新插入的结点为新的根else//原树非空时将新结点关p作为关f的左孩子或右孩子插入if(keykey)f->lchild=p;elsef->rchild=p;第16页共16页《数据结构》课程-源代码软件技术专业国家教学资源库}第16页共16页《数据结构》课程-源代码软件技术专业国家教学资源库SC020201070051.源代码编号SC020201070052.源代码来源单元7查找7.3.23.问题描述二叉排序树的生成算法4.程序代码BSTreeCreateBST(void)SC02020107005

8、{//输入一个结点序列,建立一棵二叉排序树,将根结点指针返回BSTreeT=NULL;//初始时T为空树KeyTypekey;scanf("%d",&key);//读入一个关键字while(key){//假设key=0是输入结束标志InsertBS

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。