博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++ 折半查找
阅读量:6709 次
发布时间:2019-06-25

本文共 1206 字,大约阅读时间需要 4 分钟。

静态查找表中折半查找算法的实现

注意:折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列

#include<iostream>

using namespace std;
#define ENDFLAG 10000
typedef int KeyType;
typedef char * InfoType;
typedef struct
{
 KeyType key;
 InfoType otherinfo;
}ElemType;
typedef struct
{
 ElemType *R;
 int length;
}SSTable;
void CreateSTable(SSTable &ST,int n)
{
 int i;
 ST.R=new ElemType[n+1];
 cout<<"请输入"<<n<<"个测试数据:";
 for(i=1;i<=n;i++)
  cin>>ST.R[i].key; 
 ST.length=n;
}
int Search_Bin1(SSTable ST,KeyType key)
{
 int low,high,mid;
 low=1;
 high=ST.length;
 while(low<=high)
 {
  mid=(low+high)/2;
  if(key==ST.R[mid].key) return mid;
  else if(key<ST.R[mid].key) high=mid-1;
  else low=mid+1;
 }
 return 0;
}
int Search_Bin2(SSTable ST,int low,int high,KeyType key)
{
 int mid;
 if(low>high) return 0;
 mid=(low+high)/2;
 if(key==ST.R[mid].key) return mid;
 else if(key<ST.R[mid].key) return Search_Bin2(ST,low,mid-1,key);
 else return Search_Bin2(ST,mid+1,high,key);
}

void main()

{
 int n;
 KeyType key;
 SSTable ST;
 cout<<"请输入静态查找表长:";
 cin>>n;
 CreateSTable(ST,n);
 cout<<"请输入待查记录的关键字:";
 cin>>key;
 cout<<"Search_Bin1算法计算的位置为:"<<Search_Bin1(ST,key)<<endl;
 cout<<"Search_Bin2算法计算的位置为:"<<Search_Bin2(ST,1,ST.length,key)<<endl;
}

转载于:https://www.cnblogs.com/YY-Xcode/p/4958204.html

你可能感兴趣的文章
安卓与windows
查看>>
ubuntu wifi连接出现Network service discovery disabled的解决办法
查看>>
hashlib 和 logging模块
查看>>
你不知道的JavaScript(九)switch语句
查看>>
备战招聘——信息获取与简历制作
查看>>
每天一得,能得就得~~^_^
查看>>
jsp快速学习
查看>>
01Oracle数据库系统环境搭建
查看>>
实时同步方式
查看>>
Android URLConnection发送Get请求 HttpGet封装
查看>>
在页面上实现无缝滚动
查看>>
Windows 编程1
查看>>
sublime Text使用技巧及常用插件
查看>>
Css3 Transition
查看>>
CABasicAnimation的基本使用方法(移动·旋转·放大·缩小)
查看>>
c# 使用事务
查看>>
Android使用ListView应该注意的地方
查看>>
2016-11-16试题解题报告
查看>>
bash read命令用法
查看>>
PowerEdgeR710服务器上U盘安装CentOS-5.5
查看>>