Java使用分治算法实现排序数索引功能示例【二分搜索】
本文实例讲述了Java使用分治算法实现排序数索引功能。分享给大家供大家参考,具体如下:
/**
*Findthefirstqandreturntheindex
*Firstmethodisbrutalforce
*Secondmay
*beDividandConquer
*
*@authoropen201
*
*/
publicclassOno{
/**
*f(n)=s.length=n;
*
*@params
*@paramq
*@return
*/
publicstaticintBrutalForceSearch(int[]s,intq){
for(inti=0;iendIndex)
return-1;
else{
intmid=(startIndex+endIndex)/2;
if(s[mid]==q)
returnmid;
else{
if(s[mid]>q)
returnDCSearch(s,q,startIndex,mid-1);
else
returnDCSearch(s,q,mid+1,endIndex);
}
}
}
publicstaticvoidmain(String[]args){
int[]s=newint[10000000];
for(inti=0;i<10000000;i++){
s[i]=i;
}
intq=10000000-1;
longstartTime=System.currentTimeMillis();
System.out.println(BrutalForceSearch(s,q));
longendTime=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算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。