Java数据结构--查找

简单介绍常用的查找方法:

顺序查找

从线性表开始依次查找,若找到返回索引下标,没有找到则返回-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

最常用的查找方法就是上述的顺序查找和二分查找,顺序查找效率低,但对于无序表数据查找只能采用顺序查找的方法,二分法效率相对较高,查找速度快,但只能对有序表查找。另外还有插值查找和斐波那契查找方法,原理和二分法相似,只是中间值选取的不同。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值