目录1.顺序查找介绍1.1定义1.2基本原理1.3时间复杂度与空间复杂度1.4优缺点2.代码实现2.1代码设计2.2代码实现1.顺序查找介绍1.1定义查找是指在指定数据组合中找出满...
1. 顺序查找介绍
1.1 定义
查找是指在指定数据组合中找出满足条件的元素个体。顺序查找是按照序列原有顺序对数组进行遍历比较查询的基本查找算法。
顺序查找是最基础也是最简单的查找算法,在需要进行查找时,这是我们的首选方法,只有数据较多,结构复杂,耗时较多需要优化时,我们才会考虑使用其他查找方法。
1.2 基本原理
对于任意一个序列以及一个给定的元素,从第一个序列元素开始,将给定元素与序列中元素依次比较,若某个元素与给定元素相同,则查找成功,否则,若将序列中的元素与给定元素全部比较完,依然无法匹配相同,则查找失败。
比如,拿着一张照片从一个班上找出对应学生,那么长相就是判定值,我们需要一个个学生依次去比对,长相一致则找出了该学生,如果全班都看了一遍,还是没找到,则寻人失败。
1.3 时间复杂度与空间复杂度
顺序查找平均查找长度为 (n + 1) / 2,时间复杂度为 O(n) 。
顺序查找是对数列顺序的比较,没有额外的空间,所以空间复杂度为常数 O(1)。
1.4 优缺点
优点:算法简单,对表中元素排列次序无要求,且对关键字的次序无要求,插入和删除元素都非常方便。
缺点:时间复杂度较大,当数据规模较大时,效率较低。
2. 代码实现
2.1 代码设计
a. 输入需要查找的元素key;
b. 从数组首元素(i=0)开始查找,如果array[i] = key,则查找成功返回i;
c. 否则i加1,继续查找,如果找到数组末尾,依然没找到,则查找失败,返回-1。
2.2 代码实现
#include<stdio.h>
#include<string.h>
int search(int array[],int n,int key)
{
int i;
for(i = 0; i<n; i++){
if(array[i] == key)
return i; //查找成功
}
return -1; //查找失败
}
int main(void)
{
int arr[7] = {62,8,35,22,90,58,6};
int key,ret;
printf("请输入需要查找的数字:");
scanf("%d",&key);
ret = search(arr,sizeof(arr)/4,key);
if(ret < 0)
printf("查找失败\n");
else
printf("该数字为数组第%d个元素\n",ret+1);
return 0;
}
运行结果:
请输入需要查找的数字:58
该数字为数组第6个元素
到此这篇关于C语言顺序查找算法介绍及示例的文章就介绍到这了,更多相关C语言顺序查找内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
本文标题为:C语言顺序查找算法介绍及示例


- C语言详解float类型在内存中的存储方式 2023-03-27
- 详解C语言中sizeof如何在自定义函数中正常工作 2023-04-09
- ubuntu下C/C++获取剩余内存 2023-09-18
- Qt计时器使用方法详解 2023-05-30
- Easyx实现扫雷游戏 2023-02-06
- C语言手把手带你掌握带头双向循环链表 2023-04-03
- C++ 数据结构超详细讲解顺序表 2023-03-25
- 我应该为我的项目使用相对包含路径,还是将包含目录放在包含路径上? 2022-10-30
- C语言qsort()函数的使用方法详解 2023-04-26
- c++ const 成员函数,返回一个 const 指针.但是返回的指针是什么类型的 const? 2022-10-11