package search;
public class BinarySearch{
public static int rank(int key, int[] a) {
return rank(key, a, 0, a.length - 1);
}
/**
* 根据首尾元素的比较结果判断数组的升降序
* @param key
* @param a
* @param lo
* @param hi
* @return
*/
public static int rank(int key, int[] a, int lo, int hi) {
return a[lo] < a[hi] ? rankAsc(key, a, lo, hi) : rankDesc(key, a, lo, hi);
}
/**
* 对升序数组进行查找
* @param key
* @param a
* @param lo
* @param hi
* @return
*/
public static int rankAsc(int key, int[] a, int lo, int hi) {
while(lo <= hi){
int mid = (lo + hi) / 2;
if(key < a[mid]) hi = mid - 1;
else if(key > a[mid]) lo = mid + 1;
else return mid;
}
return -1;
}
/**
* 对降序数组进行查找
* @param key
* @param a
* @param lo
* @param hi
* @return
*/
public static int rankDesc(int key, int[] a, int lo, int hi) {
while(lo <= hi){
int mid = (lo + hi) / 2;
if(key > a[mid]) hi = mid - 1;
else if(key < a[mid]) lo = mid + 1;
else return mid;
}
return -1;
}
/**
* 返回匹配键的最小索引
* @param key
* @param a
* @return
*/
public static int rankFirstIndex(int key, int[] a) {
int lo = 0;
int hi = a.length - 1;
int index = -1;
while(lo <= hi){
int mid = (lo + hi) / 2;
if(key < a[mid]) hi = mid - 1;
else if(key > a[mid]) lo = mid + 1;
else{index = mid; break;}
}
while(index > 0){
if(a[index-1] != a[index]) break;
else index--;
}
return index;
}
}
1.2.9 BinarySearch
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 每年到这个时候,身边就会有很多人开始咳嗽、咳痰、流鼻涕、打喷嚏的,有些是感冒、有些是哮喘、有些是气管炎,有些的鼻炎...
- 一般来说,喜欢站立的人,比喜欢躺着或或坐着的人,身材更好。与躺着的姿势相比,站姿所消耗的能量要多出10%。而单腿站...