数据结构之算法

算法的基本概念

计算机解题的过程实际上是在实施某种算法,这种算法称为计算机算法

算法的基本要素

一个算法是由两种基本要素组成:一是对数据对象的运算和操作;二是算法的控制结构

算法中对数据的运算和操作

在一般计算机系统中,基本运算和操作有以下4类:算术运算,逻辑运算,关系运算和数据传输

算法的控制结构

算法中各操作之间的执行顺序称为算法的控制结构

描述算法的工具通常有:N-S结构化流程图,算法描述语言等。一个算法一般都可以用顺序,选择,循环3种基本结构组合而成。

算法复杂度

算法的时间复杂度

算法的时间复杂度是指执行算法所需要的计算工作量。

同一个算法用不同的语言实现,或者用不同的编译程序进行编译,或者在不同的计算机上运行,效率均

不同。这表明使用绝对的时间单位衡量算法的效率是不合适的。撇开这些与计算机硬件、软件有关的因素, 可以认为一个特定算法"运行工作量"的大小,只依赖于问题的规模(通常用整数n表示),它是问题规模的函 数。即

算法的工作量= f ( n ) f(n) f(n)

算法的空间复杂度

一个算法所占用的存储空间包括算法程序所占的空间、输入的初始数据所占的存储空间以及算法执行过

程中所需要的额外空间。其中额外空间包括算法程序执行过程中的工作单元以及某种数据结构所需要的附加 存储空间。如果额外空间量相对于问题规模来说是常数,则称该算法是原地工作的。在许多实际问题中,为 了减少算法所占的存储空间,通常采用压缩存储技术,以便尽量减少不必要的额外空间。

疑难解答:算法的工作量用什么来计算?

算法的工作量用算法所执行的基本运算次数来计算,而算法所执行的基本运算次数是问题规模的函数,即算法的工作量=f (n),其中n是问题的规模。

相关推荐
小O的算法实验室10 分钟前
2026年ASOC,基于人工势场的差分进化算法改进框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
xieliyu.11 分钟前
Java手搓数据结构:从零模拟实现无头双向非循环链表
java·数据结构·链表
爱学习的张大15 分钟前
具身智能论文精读(五):OpenVLA
人工智能·算法
刘大猫.1 小时前
宝马发布全新AI智能座舱助手 能理解用户复杂出行需求
人工智能·算法·机器学习·ai·大模型·算力·ai智能座舱助手
如何原谅奋力过但无声1 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode
leoufung1 小时前
LeetCode 42:接雨水 —— 从“矩形法”到双指针的完整思考过程
java·算法·leetcode
_日拱一卒2 小时前
LeetCode:543二叉树的直径
算法·leetcode·职场和发展
jieyucx2 小时前
Go 数据结构入门:线性表、顺序表、链表
数据结构·链表·golang
汉克老师3 小时前
GESP2025年3月认证C++五级( 第一部分选择题(9-15))
c++·算法·高精度计算·二分算法·gesp5级·gesp五级
穿条秋裤到处跑3 小时前
每日一道leetcode(2026.04.28):获取单值网格的最小操作数
算法·leetcode·职场和发展