这篇文章主要介绍了java使用分治算法实现排序数索引功能,结合具体实例形式分析了java分治算法进行排序索引的相关操作技巧,需要的朋友可以参考下
本文实例讲述了java使用分治算法实现排序数索引功能。分享给大家供大家参考,具体如下:
/**
* find the first q and return the index
* first method is brutal force
* second may
* be pid and conquer
*
* @author open201
*
*/
public class ono {
/**
* f(n) = s.length = n;
*
* @param s
* @param q
* @return
*/
public static int brutalforcesearch(int[] s, int q) {
for (int i = 0; i < s.length; i++) {
if (q == s[i])
return i;
}
return -1;
}
/**
* f(n) = log(n)
*
* @param s
* @param q
* @return
*/
public static int dcsearch(int[] s, int q, int startindex, int endindex) {
if (startindex > endindex)
return -1;
else {
int mid = (startindex + endindex) / 2;
if (s[mid] == q)
return mid;
else {
if (s[mid] > q)
return dcsearch(s, q, startindex,mid-1);
else
return dcsearch(s, q, mid+ 1,endindex);
}
}
}
public static void main(string[] args) {
int [] s = new int[10000000];
for(int i = 0;i<10000000;i++){
s[i] = i;
}
int q = 10000000-1;
long starttime = system.currenttimemillis();
system.out.println(brutalforcesearch(s, q));
long endtime = system.currenttimemillis();
system.out.println(endtime-starttime);
starttime = system.currenttimemillis();
system.out.println(dcsearch(s, q, 0, s.length - 1));
endtime = system.currenttimemillis();
system.out.println(endtime-starttime);
}
}
以上就是java使用二分搜索法实现排序数索引功能实例讲解的详细内容。