线性查找算法

线性查找算法

生活中的例子:你有很多照片都放在了一块,你找到自己想要的一张照片,你会从第一张开始找,第一张不是,第二张不是,第三张不是。。。。以此类推,找到自己想要的,若找不到,你会感觉为什么没有,是不是丢了,心情很是低落,我草丢了!!!!!!!

程序中的例子:一个数组存储了很多数字,例如 1,2,3,4,9,5,7 这样的数据 你想查找某个数字,而你并不知道他的下标,for循环遍历,如果查询不到怎么办?程序查找不到,你是不是返回一个,我草丢了!!! 开个玩笑,找不到那就-1

JAVA代码实现线性查找算法

JAVA代码实现线性查找算法(初始版本)

/**
 * 线性查找
 */
public class LinaerSearch {

    public static void main(String[] args) {
        int [] data ={1,2,35,5,8,7,9};
        System.out.println(searchElement(data,23));//-1
        System.out.println(searchElement(data,8));//下标 4

        //JAVA
    }
    /**
     * 线性查找算法
     * @param data  数据集合
     * @param target  目标
     * @return  -1 没有找到  其他数字代表找到的 索引下标
     */
    public static int searchElement(int [] data,int target){
        //验证是否为空  如果为空  则返回 -1
        if(null==data&&data.length==0)
            return -1;

        for (int i = 0; i < data.length; i++)
            //data 下标中的数据是否等于目标
            if(data[i]==target)
                return i;
        //否则 没有查询到
        return -1;
    }
}

JAVA代码实现线性查找算法(对象版本)

/**
 * 员工实体类
 */
@Data
public class Employee {
    private String name;
    private Integer age;

    public Employee(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        Employee employee = (Employee) o;

        if (name != null ? !name.equals(employee.name) : employee.name != null) return false;
        return age != null ? age.equals(employee.age) : employee.age == null;
    }

    @Override
    public int hashCode() {
        int result = name != null ? name.hashCode() : 0;
        result = 31 * result + (age != null ? age.hashCode() : 0);
        return result;
    }
}

/**
 * 线性查找
 */
public class LinearSearch {

    public static void main(String[] args) {
     
        Employee [] employees ={new Employee("张三",29),new Employee("李四",22)};
        System.out.println(LinearSearch.<Employee>searchElement(employees,new Employee("李四",22)));
    }
    /**
     * 线性查找算法
     * @param data  数据集合
     * @param target  目标
     * @return  -1 没有找到  其他数字代表找到的 索引下标
     */
    public static <E>int searchElement(E [] data,E target){

        for (int i = 0; i < data.length; i++)
            //data 下标中的数据是否等于目标  Integer == 这里有问题  -127 128
            if(data[i].equals(target))
                return i;
        //否则 没有查询到
        return -1;
    }

线性查找算法(循环不变量版本)
众所周知,程序中有很多循环,循环开始的时候,if(判断) 是否是循环目标,data[i] 这个循环不变量的,循环体中的if就是循环不变量,证明算法的正确性

算法复杂度,性能等,线性查找算法,他是根据所查询的目标在data数组中的位置,这个算法有可能他会在最上面,也有可能在最后面,那我们考虑到最差的,我10万个元素,难道for循环遍历到最后,预估算法的上界,最差的情况进行分析,从java代码中分析->汇编指令->机器码指令->CPU硬件等等问题
它所执行的时间,时间复杂度

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值