[数组查找]1.图解线性查找及其代码实现

线性查找

线性查找是一种在数组中查找数据的算法。与二分查找不同,即便数据没有按顺序存储,也可以应用线性查找。线性查找的操作很简单,只要在数组中从头开始依次往下查找即可。虽然存储的数据类型没有限制,但为了便于理解,这里我们假设存储的是整数。

步骤:

01 来试试查找数字6

02 首先,检查数组中最左边的数字,将其与6进行比较。如果结果一致,查找便结束,不一致则向右检查下一个数字。

03 此处不一致,所以向右检查下一个数字。

04 重复上面的操作直到找到数字6为止

05 找到6了,查找结束。

解说

线性查找需要从头开始不断地按顺序检查数据,因此在数据量大且目标数据靠后,或者目标数据不存在时,比较的次数就会更多,也更为耗时。若数据量为n,线性查找的时间复杂度便为O(n)。

代码演示:

python 复制代码
def linear_search(arr, target):
    for i in range(len(arr)):
        if arr[i] == target:
            return i  # 如果找到目标元素,返回元素的索引
    return -1  # 如果数组中不存在目标元素,返回 -1


def print_result(result, target):
    if result != -1:
        print(f"目标元素 {target} 在数组中的索引为 {result}")
    else:
        print(f"目标元素 {target} 不存在于数组中")

arr = [3,9,8,2,1,4,6,5,7]

target0 = 6
result0 = linear_search(arr, target0)
print_result(result0, target0)

target1 = 100
result1 = linear_search(arr, target1)
print_result(result1, target1)

结果:

目标元素 6 在数组中的索引为 6

目标元素 100 不存在于数组中


文章来源:书籍《我的第一本算法书》

书籍链接:

我的第一本算法书 (豆瓣) (douban.com)

作者:宫崎修一 石田保辉

出版社:人民邮电出版社

ISBN:9787115495242

本篇文章仅用于学习和研究目的,不会用于任何商业用途。引用书籍《我的第一本算法书》的内容旨在分享知识和启发思考,尊重原著作者宫崎修一和石田保辉的知识产权。如有侵权或者版权纠纷,请及时联系作者。


相关推荐
GeekPMAlex几秒前
Conetext learning 3 KV-cache的提升
算法
找不到、了1 小时前
Java排序算法之<选择排序>
数据结构·算法·排序算法
是店小二呀1 小时前
【动态规划-斐波那契数列模型】理解动态规划:斐波那契数列的递推模型
算法·动态规划·代理模式
小徐不徐说2 小时前
动态规划:从入门到精通
数据结构·c++·算法·leetcode·动态规划·代理模式
guguhaohao2 小时前
排序算法,咕咕咕
数据结构·算法·排序算法
晚云与城2 小时前
【数据结构】二叉树初阶详解(二):实现逻辑与代码拆解(超详版)
数据结构
小新学习屋2 小时前
《剑指offer》-数据结构篇-树
数据结构·算法·leetcode
此心安处是吾乡10242 小时前
数据结构 双向链表
数据结构·链表
再卷也是菜2 小时前
数据结构(4)单链表算法题(上)
数据结构
好心的小明2 小时前
【深度之眼机器学习笔记】04-01-决策树简介、熵,04-02-条件熵及计算举例,04-03-信息增益、ID3算法
笔记·算法·决策树