数据结构之算法

算法的基本概念

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

算法的基本要素

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

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

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

算法的控制结构

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

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

算法复杂度

算法的时间复杂度

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

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

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

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

算法的空间复杂度

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

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

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

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

相关推荐
hnjzsyjyj10 小时前
东方博宜OJ 2190:树的重心 ← 邻接表 or 链式前向星
数据结构·链式前向星·树的重心
yaoh.wang12 小时前
力扣(LeetCode) 13: 罗马数字转整数 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
ChoSeitaku12 小时前
NO15数据结构选择题考点|线性表|栈和队列|串
数据结构
T1ssy13 小时前
布隆过滤器:用概率换空间的奇妙数据结构
算法·哈希算法
hetao173383713 小时前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法
一直都在57213 小时前
数据结构入门:时间复杂度与排序和查找
数据结构
鲨莎分不晴14 小时前
强化学习第五课 —— A2C & A3C:并行化是如何杀死经验回放
网络·算法·机器学习
搞科研的小刘选手15 小时前
【ISSN/ISBN双刊号】第三届电力电子与人工智能国际学术会议(PEAI 2026)
图像处理·人工智能·算法·电力电子·学术会议
拉姆哥的小屋15 小时前
从混沌到秩序:条件扩散模型在图像转换中的哲学与技术革命
人工智能·算法·机器学习
Sammyyyyy15 小时前
DeepSeek v3.2 正式发布,对标 GPT-5
开发语言·人工智能·gpt·算法·servbay