给一个严格递增数列,函数 int Search_Bin(SSTable T, KeyType k) 用来二分地查找 k 在数列中的位置。
函数接口定义:
int Search_Bin(SSTable T, KeyType k)
其中 T 是有序表,k 是查找的值。
裁判测试程序样例:
#include <iostream>
using namespace std;
#define MAXSIZE 50
typedef int KeyType;
typedef struct
{ KeyType key;
} ElemType;
typedef struct
{ ElemType *R;
int length;
} SSTable;
void Create(SSTable &T)
{ int i;
T.R=new ElemType[MAXSIZE+1];
cin>>T.length;
for(i=1;i<=T.length;i++)
cin>>T.R[i].key;
}
int Search_Bin(SSTable T, KeyType k);
int main ()
{ SSTable T; KeyType k;
Create(T);
cin>>k;
int pos=Search_Bin(T,k);
if(pos==0) cout<<"NOT FOUND"<<endl;
else cout<<pos<<endl;
return 0;
}
/* 请在这里填写答案 */
输入格式:
第一行输入一个整数 n,表示有序表的元素个数,接下来一行 n 个数字,依次为表内元素值。 然后输入一个要查找的值。
输出格式:
输出这个值在表内的位置,如果没有找到,输出 “NOT FOUND”。
输入样例1:
5
1 3 5 7 9
7
输出样例1:
4
输入样例2:
5
1 3 5 7 9
10
输出样例2:
NOT FOUND
来源:
来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/14/exam/problems/44932
提交:
题解:
/*
* 二分地查找 k 在数列中的位置
*/
int Search_Bin(SSTable T, KeyType k) {
KeyType l = 0;
KeyType r = T.length;
KeyType mid = (l + r) / 2;
while (l <= r) {
if (T.R[mid].key == k) {
// 成功找到 k
return mid;
} else if (T.R[mid].key < k) {
// k 位于后半区间,下限后移
l = mid + 1;
} else {
// k 位于前半区间,上限前移
r = mid - 1;
}
mid = (l + r) / 2;
}
return 0;
}