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程序设计有所帮助。