学知识一定要记住口诀,才能学的好,学的快!分享一篇最简单的查找算法--顺序查找。
顺序查找秘诀:遍历数组元素,逐个查找,匹配
int main(int argc, const char * argv[])
{
@autoreleasepool {
int i, x, n = 0;
int a[10];
printf("请输入10个数字!\n");
for (i = 0; i < 10; i++) {
scanf("%d", &a[i]);
}
printf("请输入要查找的数:");
scanf("%d", &x);
n = orederSearch(a, x);
if (n < 0) {
printf("没有找到您要找的数。\n");
}
else{
printf("您要找的数%d,在数组中第%d个元素处。\n", x, n);
}
}
return 0;
}
int orederSearch(int a[], int x)
{
int i, f=-1, num = 0;
for (i = 0; i < 10; i++)
if (x == a[i])
{
f = i + 1;
num++;
break;
}
return f;
}
(注:上面的代码,只能找到一个数字,不能找到重复的数字。有兴趣的话,可以完善下,呵呵。)
1.顺序查找是在一个无序队列中找出与给定关键字相同的数的具体位置。
原理是让关键字与队列中的数从第一个开始逐个比较,直到找出与给定关键字相同的数或者搜索完整个数据列为止。
2.优点:算法简单且对表的结构无任何要求。无论是用向量还是用链表来存放结点,而且不管结点之间是否有序,它都是适用的。
3.缺点:查找效率低。因此,当数据量较大时不宜采用顺序查找。最理想的情况是比较一次就能够找到目标数据,最差的情况是需要比较完所有的数据后才能找到目标数据,平均比较次数为n/2次。
致力于ios开发
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架