当前位置: 首页 > news >正文

C语言经典算法之顺序查找算法

目录

前言

A.建议

B.简介

一 代码实现

二 算法时空复杂度

A.时间复杂度:

B.空间复杂度:

三 优点和缺点

A.优点:

B.缺点:

四 现实中的应用


前言

A.建议

1.学习算法最重要的是理解算法的每一步,而不是记住算法。

2.建议读者学习算法的时候,自己手动一步一步地运行算法。

tips:文中的对数均以2为底数

B.简介

顺序查找是一种简单的查找算法,也称为线性查找。它的基本思想是逐个检查待查找元素是否与数组中的元素相等,直到找到目标元素或搜索完整个数组。

一 代码实现

#include <stdio.h>// 顺序查找函数
int sequentialSearch(int arr[], int n, int target) {for (int i = 0; i < n; i++) {if (arr[i] == target) {return i;  // 找到目标元素,返回索引}}return -1;  // 未找到目标元素,返回-1
}int main() {int arr[] = {2, 5, 8, 12, 16, 23, 38, 45, 56, 72};int n = sizeof(arr) / sizeof(arr[0]);int target = 23;int result = sequentialSearch(arr, n, target);if (result != -1) {printf("目标元素 %d 在数组中的索引是 %d\n", target, result);} else {printf("未找到目标元素 %d\n", target);}return 0;
}

这个例子中,sequentialSearch 函数接受一个整数数组、数组长度和目标元素作为参数,返回目标元素在数组中的索引。在 main 函数中,我们定义了一个数组,调用 sequentialSearch 函数来查找目标元素的位置,并输出查找结果。

二 算法时空复杂度

A.时间复杂度:

在最坏的情况下,顺序查找需要遍历整个数组才能确定目标元素是否存在。因此,最坏情况下的时间复杂度是O(n),其中n是数组的长度。

最好情况发生在目标元素在数组的第一个位置,此时算法只需要一次比较就找到了目标元素。因此,顺序查找算法的最好时间复杂度为 O(1)

在平均情况下,假设目标元素在数组中的位置是等概率的,则平均查找次数为 (n+1)/2。因此,平均情况下的时间复杂度也是O(n)

B.空间复杂度:

顺序查找算法是原地算法,它不需要额外的空间来存储中间结果,只需要少量的额外空间用于存储变量和参数。因此,空间复杂度是O(1)。

三 优点和缺点

A.优点:

简单直观: 顺序查找是一种直观且易于理解的查找算法,无需复杂的数据结构或算法设计。

适用于小规模数据: 在小规模数据集中,顺序查找的性能相对较好,因为它的常数因子较小,不会引入过多的开销。

适用于无序数据: 顺序查找不依赖于数据的有序性,适用于无序的数据集。

B.缺点:

时间复杂度高: 在最坏情况下,顺序查找需要遍历整个数据集,因此其最坏时间复杂度是O(n),其中 n 是数据集的大小。对于大规模数据集,性能相对较差。

不适用于有序数据: 如果数据集是有序的,其他更高效的查找算法,如二分查找,通常会更加适用。顺序查找在这种情况下的性能不如一些针对有序数据设计的算法。

性能对数据分布敏感: 顺序查找的性能受到数据分布的影响。如果目标元素在数据集的前部分,性能相对较好;如果目标元素在后部分,性能较差。

四 现实中的应用

应用场景如下:

小规模数据集: 当数据集规模较小,且没有明显的顺序结构时,顺序查找可能是一种简单而直观的选择。由于顺序查找的时间复杂度是线性的,对于小规模数据,性能影响相对较小。

无序数据集: 如果数据集是无序的,而且没有其他信息可以利用,顺序查找是一种合理的选择。在这种情况下,其他更复杂的算法可能不会带来太大的优势,因为它们的性能可能会受到数据分布的影响。

调试和验证: 顺序查找可以用于验证其他更高级查找算法的正确性。在实现更复杂的算法之前,可以使用顺序查找验证预期的结果。

相关文章:

C语言经典算法之顺序查找算法

目录 前言 A.建议 B.简介 一 代码实现 二 算法时空复杂度 A.时间复杂度&#xff1a; B.空间复杂度&#xff1a; 三 优点和缺点 A.优点&#xff1a; B.缺点&#xff1a; 四 现实中的应用 前言 A.建议 1.学习算法最重要的是理解算法的每一步&#xff0c;而不是记住算…...

c语言嵌套循环

c语言嵌套循环 c语言嵌套循环 c语言嵌套循环一、c语言嵌套循环格式二、嵌套循环案例九九惩罚口诀 一、c语言嵌套循环格式 for(初始值&#xff1b;表达式&#xff1b;表达式) {for&#xff08;初始值&#xff1b;表达式&#xff1b;表达式&#xff09;{代码} }int main() {for (…...

磁盘位置不可用怎么修复?

磁盘位置不可用是计算机使用中经常遇到的问题。造成磁盘位置不可用的原因有多种&#xff0c;其中最常见的是磁盘文件系统损坏。当文件系统损坏时&#xff0c;操作系统无法正常访问磁盘上的数据&#xff0c;导致磁盘位置不可用。 磁盘位置不可用怎么修复&#xff1f; 当磁盘位置…...

【总结】Linux命令中文帮助手册

1. 为什么要总结Linux命令中文帮助手册 Linux 官方并不提供中文的 help、man 帮助手册。网络上已有的前人翻译过的中文手册版本比较老&#xff0c;且翻译存在误差。从记忆角度来看&#xff0c;Linux 很多命令都不一定记得住详细的用法&#xff0c;易遗忘&#xff0c;缺少经验总…...

[贪心算法] 国王游戏

题目描述 ​ 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏。首先,他让每个大臣在左、右手上面分别写下一个整数&#xff0c;国王自己也在左、右手上各写一个整数。然后&#xff0c;让这 n 位大臣排成一排&#xff0c;国王站在队伍的最前面。排好队后&#xff0c;所有的大…...

meter报OOM错误,如何解决?

根据在之前的压测过程碰到的问题&#xff0c;今天稍微总结总结&#xff0c;以后方便自己查找。 一、单台Mac进行压测时候&#xff0c;压测客户端Jmeter启动超过2000个线程&#xff0c;Jmeter报OOM错误&#xff0c;如何解决&#xff1f; 解答&#xff1a;单台Mac配置内存为8G&…...

第二百六十九回

文章目录 概念介绍设置方法示例代码内容总结 我们在上一章回中介绍了Card Widget相关的内容&#xff0c;本章回中将介绍国际化设置.闲话休提&#xff0c;让我们一起Talk Flutter吧。 概念介绍 我们在这里说的国际化设置是指在App设置相关操作&#xff0c;这样可以让不同国家的…...

未来能源转型之路:2023年第十三届中国国际储能大会启示录

在2023年第十三届中国国际储能大会上&#xff0c;全球各地的能源专家、学者和企业代表齐聚一堂&#xff0c;共同探讨了储能技术在推动能源转型中的重要作用。对于我们普通人来说&#xff0c;从这场大会中可以学到什么呢&#xff1f; 一、储能技术是未来能源发展的关键 随着可再…...

rviz可视化机械臂(python)

一、准备的东西 一个机械臂的urdf 规划的路径点 二、launch文件的撰写 1.初始化 <?xml version"1.0" encoding"utf-8"?> <launch><param name"robot_description" textfile"机械臂.urdf" /><node name&qu…...

《设计模式的艺术》笔记 - 享元模式

介绍 享元模式运用共享技术有效地支持大量细粒度对象的复用。系统只使用少量的对象&#xff0c;而这些对象都很相似&#xff0c;状态变化很小&#xff0c;可以实现对象的多次复用。由于享元模式要求能够共享的对象必须是细粒度对象&#xff0c;因此它又称为轻量级模式&#xff…...

ubuntu系统(10):使用samba共享linux主机中文件

目录 一、samba安装步骤 1、Linux主机端操作 &#xff08;1&#xff09;安装sabma &#xff08;2&#xff09;修改samba配置文件 &#xff08;3&#xff09;为user_name用户设置samba访问的密码 &#xff08;4&#xff09;重启samba服务 2、Windows端 二、使用 1、代码…...

数据集成时表模型同步方法解析

01 背景介绍 数据治理的第一步&#xff0c;也是数据中台的一个基础功能 — 即将来自各类业务数据源的数据&#xff0c;同步集成至中台 ODS 层。业务数据源多种多样&#xff0c;单单可能涉及到的主流关系型数据库就有近十种。功能更加全面的数据中台通常还具有对接非关系型数据…...

彻底解决charles抓包https乱码的问题

最近做js逆向&#xff0c;听说charles比浏览器抓包更好用&#xff0c;结果发现全是乱码&#xff0c;根本没法用。 然后查询网上水文&#xff1a;全部都是装证书&#xff0c;根本没用&#xff01; 最后终于找到解决办法&#xff0c;在这里记录一下&#xff1a; 乱码的根本原因…...

Towards Robust Blind Face Restoration with Codebook Lookup Transformer

Towards Real World Blind Face Restoration with Generative Facial Prior 这个projec相对codeformer已经是老一些的了&#xff0c;CodeFormer paper说自己的效果比这个更好。 有看了这个视频&#xff0c;它借用了R-ESRGAN 4x 和 GFPGAN 50%&#xff0c;既保留了一些人物特征…...

flutter3使用dio库发送FormData数据格式时候的坑,和get库冲突解决办法

问题描述 问题1&#xff1a;当你使用FormData.from(Flutter3直接不能用)的时候&#xff0c;可能会提示没有这个方法&#xff0c;或者使用FormData.fromMap(flutter3的dio支持)的时候也提示没有&#xff0c;这时候可能就是和get库里面的Formdata冲突了 问题1&#xff1a;The me…...

matlab读取pwm波数据,不用timer的方法,这里可以参考。Matlab/Simulink之STM32开发-编码器测速

这里提供了一个不用timer的方法&#xff0c;可以参考&#xff1a; https://blog.csdn.net/weixin_36967309/article/details/88699830 Matlab/Simulink之STM32开发-编码器测速...

使用 Python 创造你自己的计算机游戏(游戏编程快速上手)第四版:第十九章到第二十一章

十九、碰撞检测 原文&#xff1a;inventwithpython.com/invent4thed/chapter19.html 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 碰撞检测涉及确定屏幕上的两个物体何时相互接触&#xff08;即发生碰撞&#xff09;。碰撞检测对于游戏非常有用。例如&#xff0c;如…...

Multimodal Multitask Learning with a Unified Transformer

SNLI-VE dataset&#xff0c;natural language understanding tasks&#xff1a;MNLI&#xff0c;QNLI&#xff0c;QQP&#xff0c;SST-2 截止到发文时间的issue数&#xff0c;多吓人呐&#xff0c;不建议复现...

c指针和字符数组初学者比较好的例子

本练习的主题&#xff1a;一个对象的指针可以修改这个对象的内容&#xff1b; 注&#xff1a;对象是指一个固定大小的内存块。 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> #include <stdlib.h> int getMem(char **p1,int *m…...

微信原生小程序上传与识别以及监听多个checkbox事件打开pdf

1.点击上传并识别 组件样式<van-field border"{{ false }}" placeholder"请输入银行卡卡号" model:value"{{bankNo}}" label"卡号"><van-icon bindtap"handleChooseImg" slot"right-icon" name"sca…...

DBA必看:Oracle OCP认证到底值不值得考?2024年最新薪资与职业发展分析

Oracle OCP认证2024深度评测&#xff1a;从薪资数据到职业跃迁的实战指南 在数据库技术领域&#xff0c;Oracle始终占据着不可撼动的地位。每当我在技术社区看到年轻DBA们关于职业认证的讨论&#xff0c;总会被问到同一个问题&#xff1a;"Oracle OCP认证在2024年还值得投…...

PinButtonEvents:嵌入式按钮事件处理框架深度解析

1. PinButtonEvents 库深度解析&#xff1a;面向嵌入式系统的高可靠性按钮事件处理框架在嵌入式系统开发中&#xff0c;按钮输入看似简单&#xff0c;实则暗藏诸多工程陷阱&#xff1a;机械触点抖动导致的误触发、长按与短按的语义混淆、双击/多击行为的时序判定、低功耗场景下…...

嵌入式系统分层架构设计与驱动框架实现

1. 嵌入式系统中的分层架构设计在嵌入式开发领域&#xff0c;我一直坚持一个核心原则&#xff1a;好的代码结构应该像洋葱一样层次分明。以STM32开发为例&#xff0c;很多初学者直接从官方例程入手时&#xff0c;往往会发现应用层代码中混杂着大量硬件相关的头文件引用&#xf…...

MATLAB FFT 入门到实战:信号分析与频率分解的完整指南

文章目录What Is FFT, Anyway?MATLAB FFT Basics: Step-by-Step Code3 Common FFT Pitfalls (And How to Fix Them)1. Forgetting to Scale Magnitude2. Ignoring SymmetryAdvanced Tips to Level Up Your FFT GameZero-Padding for Smoother PlotsFiltering Noisy SignalsRea…...

低噪放(LNA)关键参数在5G通信电路设计中的优化策略

1. 5G时代LNA设计的核心挑战 当你用手机刷短视频时&#xff0c;可能不会想到信号要经历一场"马拉松"——从基站出发&#xff0c;穿过建筑、树木、甚至雨雾&#xff0c;最终到达你掌心大小的设备。而这场马拉松的第一棒选手&#xff0c;就是藏在手机射频前端的低噪声…...

第6章 Mosquitto用户认证与访问控制

第6章 用户认证与访问控制 6.1 认证机制概览 #mermaid-svg-MTeZFweZQcx9XrLR{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}@keyframes edge-animation-frame{from{stroke-dashoffset:0;}}@keyframes dash{to{stroke-dashoffset:…...

新企业应该优先选择SEO还是网络推广_SEO和网络推广的具体操作方法有哪些

新企业应该优先选择SEO还是网络推广_SEO和网络推广的具体操作方法有哪些 在数字化营销的时代&#xff0c;新企业在选择推广策略时面临着两大选择&#xff1a;SEO&#xff08;搜索引擎优化&#xff09;和网络推广。两者各有优劣&#xff0c;本文将详细探讨新企业应优先选择哪种…...

深度学习概率分布与核心运算 —— 概率论的工具箱(八)

1. 定位导航 上一篇回答了"为什么需要概率"。本篇开始构建概率论的基本工具箱——这些工具是理解后续所有内容(损失函数、贝叶斯推断、生成模型、信息论)的数学基础。 本篇覆盖六大核心概念:随机变量与概率分布(PMF/PDF)、边缘概率、条件概率、链式法则、独立…...

知识竞赛在党建教育中的创新应用:激活学习动能,赋能组织活力

引言&#xff1a;党建教育需要新载体在新时代背景下&#xff0c;党建教育工作面临着党员群体年轻化、信息获取渠道多元化、学习需求个性化等新挑战。传统的单向宣讲、文件学习模式有时难以充分激发党员的学习热情和深度参与。因此&#xff0c;探索形式新颖、互动性强、富有时代…...

Anthropic 源代码泄露:Claude Code 安全漏洞敲响 AI 警钟

Claude Code 源代码泄露&#xff0c;安全防线告急 人工智能公司 Anthropic 遭遇了严重的源代码泄露事件&#xff0c;此次事件直接影响了其 Claude Code 工具的安全性。研究人员在泄露的代码中发现了一个关键漏洞&#xff0c;这一漏洞的存在使得 Claude Code 可能执行其本不愿执…...