二分查找Ⅱ
提交数: 3200, 通过率: 33.56%, 平均分: 43.71
题目描述:
给定一个包含n个关键字的有序(从小到大排列)数列,采用“二分查找算法”查找关键字x。要求输出:关键字的位置及进行比较的次数。
输入格式:
第一行一个整数n(n<=100,000)。
第二行包含n个从小到大有序的整数,各数之间用一个空格隔开。
第三行一个整数x。
输出格式:
两个整数,表示x所在的位置以及比较的总次数。
样例输入:
10 1 2 3 4 5 6 7 8 9 10 9
样例输出:
9 3
提示:
二分查找算法
因为整个序列已经有序(从小到大排),所以我们每次可以和区间的中间那个数去比较,比较的有三种情况:
1)相等,即找到;
2)如果要找的数比中间的那个数大,接下来在后半段继续找。
3)如果要找的数比中间的那个数小,接下来在前半段继续找。
样例解释:第1次和序列中的5比较,第2次和序列中的8比较,第3次和序列中的9比较。
时间限制: 1000ms空间限制: 128MB
来源: 原创