PAT基础题 4-13 折半查找
来源:互联网 发布:python numpy 编辑:程序博客网 时间:2024/05/21 13:46
给一个严格递增数列,函数int binSearch(SeqList T, KeyType k)用来二分地查找k在数列中的位置。
函数接口定义:
int binSearch(SeqList T, KeyType k)
其中T是有序表,k是查找的值。
裁判测试程序样例:#include <iostream>using namespace std;#define MAXLEN 50typedef int KeyType;typedef struct { KeyType key; } elementType; typedef struct{ elementType data[MAXLEN+1]; int len;} SeqList; void creat(SeqList &L){ int i; cin>>L.len; for(i=1;i<=L.len;i++) cin>>L.data[i].key; }int binSearch(SeqList T, KeyType k);int main () { SeqList L; KeyType k; creat(L); cin>>k; int pos=binSearch(L,k); if(pos==0) cout<<"NOT FOUND"<<endl; else cout<<pos<<endl; return 0;}/* 请在这里填写答案 */
输入格式:
第一行输入一个整数n,表示有序表的元素个数,接下来一行n个数字,依次为表内元素值。 然后输入一个要查找的值。
输出格式:
输出这个值在表内的位置,如果没有找到,输出”NOT FOUND”。
输入样例:
5
1 3 5 7 9
7
输出样例:
4
输入样例:
5
1 3 5 7 9
10
输出样例:
NOT FOUND
int binSearch(SeqList T, KeyType k){ int Low,Mid,High; Low=1;High=T.len; while(Low<High) { Mid=(Low+High)/2; if(T.data[Mid].key<k) Low=Mid+1; else if(T.data[Mid].key>k) High=Mid-1; else return Mid; } return 0;}
阅读全文
0 0
- PAT基础题 4-13 折半查找
- 4-13 折半查找
- 基础算法之五-查找: 折半查找
- 4-13 折半查找 (15分)
- 4-13 折半查找 (15分)
- MOOC清华《程序设计基础》第4章:查找扑克牌(折半查找)
- 数据结构基础之折半查找与插值查找
- (基础十)折半查找的实现(二分查找)
- 算法基础(一)------ 二分查找(折半查找)
- 折半查找
- 折半查找
- 折半查找
- 折半查找
- 折半查找
- 折半查找
- 折半查找
- 折半查找
- 折半查找
- 单片机复位电路原理介绍
- Android开发的经典入门教材和学习路线
- NKOJ 1979 投票
- 小 X的密室
- TensorFlow中常见的由于API版本问题导致的错误汇总
- PAT基础题 4-13 折半查找
- jetson TX2如何安装opencv3.0
- [LintCode]245.子树
- ubuntu配置vps+ss
- LeetCode:38.Count and Say
- CentOS6.5安装elasticsearch-5.5.1以及elasticsearch-sql插件安装
- PE文件学习笔记(一):DOS头与PE头解析
- linux各种中文乱码解决办法整理
- LeetCode