简单介绍常用的查找方法:
顺序查找
从线性表开始依次查找,若找到返回索引下标,没有找到则返回-1。
//顺序查找
public int seqSearch(int[] data,int key){
int index;
for(index=0;index<data.length;index++){
if(data[index]==key)return index;
}
return -1;
}
顺序查找对数据依次查找,效率不是很高,但是在一些情况下,只能采用顺序查找:
1.数据无序;
2.在链表中查找。
二分查找
二分法查找针对的是有序线性表数据,二分有序表,依次1/2的缩小数据所在的范围。二分法每次可以将范围缩小一半,效率较高,查找速度较快,适用于较长的线性表的查找。
//二分查找
static public int binSearch(int[] data,int key){
int low = 0;
int high = data.length-1;
if(key<data[0]||key>data[data.length-1])return -1;
while(high>=low){
if(data[(high+low)/2]==key)return (high+low)/2;
if(data[(high+low)/2]>key)high = (high+low)/2-1;
if(data[(high+low)/2]<key)low = (high+low)/2+1;
}
return -1;
}
//引用
int[] data = {1,3,5,6,7,8,9};
System.out.println(binSearch(data,5));//2
最常用的查找方法就是上述的顺序查找和二分查找,顺序查找效率低,但对于无序表数据查找只能采用顺序查找的方法,二分法效率相对较高,查找速度快,但只能对有序表查找。另外还有插值查找和斐波那契查找方法,原理和二分法相似,只是中间值选取的不同。