查找算法--顺序法(Java实现)

简介:

顺序查找法又称线性查找法,是一种最简单的查找法。该算法的原理是将数据一个一 个地按顺序逐次查找。所以不管数据的顺序是什么样的,都得从头到尾遍历一次。

优点: 文件在查找前不需要作任何的处理与排序
缺点: 是查找速度较慢

算法实现:

public	static int linear_search(int arr[], int len, int key)
    {
    	int pos=-1;     //设置pos=-1是为了防止数组中没有目标值时返回一个随机值
    	for(int i=0;i<len;i++)
    		if(arr[i]==key)
    			pos= i;
    	return pos;
    }

注:该算法效果是若查找的数组中有重复元素,则返回最后一个目标值的下标

算法另一种实现:

public static int better_linear_search(int arr[],int len,int key)
	{   
		for(int i=0;i<len;i++)
			if(arr[i]==key)
	          return i;  //发现key值就返回下标
		   
		return -1;
		
	}

注:这个算法的效果是发现目标值就返回下标,当数组中有重复元素时,返回第一个元素的下标

算法进一步优化:

public static int sentinel_linear_search
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值