算法分析01--算法的基本概念

news2024/11/21 2:25:45

1.算法设计与分析的基本概念

1.1算法

算法(Algorithm)是对特定问题求解步骤的一种描述, 它是指令的有限序列, 其中每一条指令表示一个或多个操作。

算法具有以下5个重要特性:

1.有穷性 一个算法必须在有穷步内完成,并且每一步都在有穷时间内完成。

2.确定性 算法中每一条指令必须有确切的含义,并且只有唯一的执行路径。

3.可行性 算法中描述的操作都可通过已经实现的基本运算进行有限次完成。

4.输入 有零个或多个输出。

5.输出 有一个或多个输出,是与输入有某些特定关系的量。

1.2算法设计

设计一个 “好 ” 的算法应考虑多个目标, 包括正确性、 可读性、 健壮性和高效性等。

存在多种算法设计技术(也称为算法设计策略), 它们是设计算法的一般性方法。 已经证明这些技术对千设计好的算法非常有用, 在掌握了这些技术之后, 设计新的和有用的算法会变得容易。经常采用的算法设计技术主要有分治法、 动态规划法、 贪心法、 回溯法、 分支限界法、概率算法和近似算法等。

1.3算法分析

求解一个问题可能会有多种算法可以选择, 选择的主要标准首先是算法的正确性、可靠性、 简单性和易理解性, 其次是算法的时间复杂度和空间复杂度要低。

算法分析是指对一个算法所需要的资源进行估算, 这些资源包括内存、 通信带宽、 计算机硬件和时间等, 所需要的资源越多, 该算法的复杂度就越高。

对千任何给定的问题, 设计出复杂度尽可能低的算法是设计算法时追求的重要目标。 另一方面 ,当给定问题有很多种算法时, 选择其中复杂度最低者是一个重要准则。

1.4算法表示

常用的表示算法的方法有自然语言、 流程图、 程序设计语言和伪代码等。
(1)自然语言。其最大的优点是容易理解, 缺点是容易出现二义性, 并且算法通常很冗长。
(2)流程图。其优点是直观易懂 , 缺点是严密性不如程序设计语言, 灵活性不如自然语言。
(3)程序设计语言。其优点是能用计算机直接执行, 缺点是抽象性差, 使算法设计者拘泥于描述算法的具体细节, 忽略了 “好” 算法和正确逻辑的重要性。 此外, 还要求算法设计者掌握程序设计语言及编程技巧。
(4) 伪代码。伪代码是介于自然语言和程序设计语言之间的方法, 它采用某一程序设计语 言的基本语法, 同时结合自然语言来表达。 计算机科学家从来没有对伪代码的书写形式达成过共识。在伪代码中, 可以采用最具表达力的、最简明扼要的方法来表达一个给定的算法。

2.算法分析

2.1算法复杂度

算法复杂度是衡量算法性能的度量标准,它描述了算法运行时间(时间复杂度)或者空间占用(空间复杂度)随着问题规模增加而增长的趋势。

2.2时间复杂度

在算法分析中, 可以建立以输入规模 n 为自变量的函数 T(n)来表示算法的时间复杂度。
根据不同的输入,将算法的时间复杂度分析分为3种情况。
(1)最佳情况。 使算法执行时间最少的输入。一般情况下, 不进行算法在最佳情况下的时间复杂度分析。应用最佳情况分析的一个例子是已经证明基于比较的排序算法的时间复杂度下限为O(nlgn) 。
(2)最坏情况。 使算法执行时间最多的输入。 一般会进行算法在最坏时间复杂度的分析, 因为最坏情况是在任何输入下运行时间的一个上限, 它给我们提供一个保障, 实际情况不会比这更糟糕。另外,对于某些算法来说, 最坏情况还是相当频繁的。 而且对于许多算法来说, 平均情况通常与最坏情况下的时间复杂度一样。
(3)平均情况。 算法的平均运行时间, 一般来说, 这种情况很难分析。举个简单的例子, 现要排序10个不同的整数, 输入就有10!种不同的情况, 平均情况的时间复杂度要考虑每一种输入及其该输入的概率。 平均情况分析可以按以下3个步骤进行:
①将所有的输入按其执行时间分类。
②确定每类输入发生的概率。
③确定每类输入的执行时间。

  • 算法的时间复杂度(time complexity)是一个函数,它定性描述该算法的运行时间。这是一个代表算法输入值的字符串的长度的函数。
  • 时间复杂度常用大O表示法,即去掉这个函数的低阶项和首项系数。
  • 相同大小的不同输入值仍可能造成算法的执行时间不同,因此我们通常使用算法的最坏情况复杂度。
  • 在实际计算中,通过计算基本操作的次数来获取时间复杂度。

常见的时间复杂度有(从小到大):

  • 常数时间 O(1)
  • 对数时间 O(log n)
  • 线性时间 O(n)
  • 线性对数时间 O(n log n)
  • 平方时间 O(n2)
  • 立方时间 O(n3)
  • 指数时间 O(2n)
  • 阶乘时间 O(n!)

2.3空间复杂度

空间复杂度:用来衡量算法执行所需的额外空间资源。

常见的空间复杂度有:
常数空间 O(1)
线性空间 O(n)
线性对数空间 O(n log n)
平方空间 O(n2)

2.4渐进符号

(1)O记号。 定义为:给定一个函数 g(n), O(g(n)) ={f{n)存在正常数 c 和 n0,使得对所有
n>=n0,有0<=f(n)<=cg(n)}
(2)Ω 记号。定义为:给定一个函数 g(n), Ω(g(n)) ={f{n)存在正常数 c 和 n0, 使得对所有n>=n0,有0<=cg(n)<=f(n)}
(3)Θ 记号。定义为:定义为:给定 个函数 g(n), 0(g(n)) ={f{n)存在正常数c1、c2和 n0,使得对所有n>=n0,有0<=c1g(n)<=f(n)<=c2g(n)}

由上述定义可知, f(n)= 0(g(n))当且仅当f(n)=O(g(n))和f(n)=Ω(g(n))。

2.5求解递归式

算法可以分为非递归形式和递归形式。非递归算法的时间复杂度分析比较简单,本节主要讨论递归算法的时间复杂度分析方法。
(1) 展开法。将递归式中等式右边的项根据递归式进行替换, 称为展开。展开后的项被再
次展开, 如此下去, 直到得到一个求和表达式, 得到结果。
在这里插入图片描述

(2) 主方法求解递归式。T(n)=aT(n/b)+f(n)递归式描述一种算法运行时间:它将规模为n的问题分解为a个子问题,每个子问题的规模为n/b,其中a和b都为正常数。a个子问题递归的求解,每个花费时间为T(n/b)。函数f(n)包含了问题分解和子问题解合并的代价。

  • 若对某个常数 ε>0 有 f(n) = O(nlogba-ε),则 T(n) = Θ(nlogba) 。
  • 若 f(n) = Θ(nlogbalgkn),则 T(n) = Θ(nlogba lgk+1n) 。
  • 若对某个常数 ε>0 有 f(n) = Ω(nlogba+ε),且对某个常数 c<1 和所有足够大的 n 有 af(n/b) ≤ cf(n),则 T(n) = Θ(f(n)) 。

(3)递归树法。
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/669160.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue2 到 Vue3, 5 个常用API的变化有哪些

Vue3之于Vue2最大的变化&#xff0c;当属composition API了&#xff0c;而除了引入composition API外&#xff0c;一些我们在Vue2上经常使用的东西到了Vue3时也发生了不小的变化&#xff0c;本文将介绍一些有Vue2到Vue3中几个比较重要且常用的知识点&#xff0c;欢迎感兴趣的同…

学习adaboost(一,遍历分类器,c#实现)

我看了很多遍&#xff0c;终于搞懂了&#xff0c;现在编程试一试&#xff0c; 参考文献&#xff08;十三&#xff09;通俗易懂理解——Adaboost算法原理 - 知乎 (zhihu.com) 先写一一段代码&#xff0c;把这个数据集里头的所有分类器找出来&#xff1a;一共四种结果&#xff1a…

C++基础(4)——类和对象(2)

前言 本文主要介绍了C中类和对象的基本知识。 4.2.5&#xff1a;深拷贝和浅拷贝 浅拷贝&#xff1a;编译器给我们提供的拷贝函数就是等号复制操作 深拷贝&#xff1a;自己手动重写一个拷贝构造函数&#xff0c;重新new 浅拷贝会出现的问题&#xff1a;如果使用编译器提供的…

CSS3-背景

背景 1 背景颜色 2 背景图片 3 背景平铺 4 背景位置 5 背景相关属性连写 6&#xff08;拓展&#xff09;img标签和背景图片的区别 1 背景颜色 属性名&#xff1a;background-color 取值&#xff1b;关键字、rgb表示法、rgba表示法、十六进制 注意&#xff1a; 1 背景颜色默认值…

基于Java中小企业人力资源管理系统设计实现(源码+lw+部署文档+讲解等)

博主介绍&#xff1a; ✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战 ✌ &#x1f345; 文末获取源码联系 &#x1f345; &#x1f447;&#x1f3fb; 精…

CSS查缺补漏之《常用文本属性、列表属性、表格属性、鼠标属性》

文本属性 letter-spacing&#xff1a; 表示字母或汉字间距&#xff1b; word-spacing&#xff1a;表示单词之间或汉字之间空格的间距 <div>Loremip sumdolors itametconsecteturadipisicingelit.Voluptas.</div> <div>这是一首简单的小情歌 唱着我们心肠的曲…

chatgpt赋能python:Python数据归一化:什么是数据归一化及其作用

Python数据归一化&#xff1a;什么是数据归一化及其作用 数据归一化是一个在数据分析中经常出现的术语。其目的是将数据缩放到相同的比例&#xff0c;从而进行更加准确和可靠的分析。在本文中&#xff0c;我们将介绍什么是数据归一化&#xff0c;为什么我们需要它以及如何在Py…

Element-ui 滚动条美化

目录 1、缘起 2、实际示例 3、美化滚动条 4、Element-plus中的滚动条 5、关于实现方式的思考 1、缘起 之前在做项目时&#xff0c;发现一个项目中&#xff0c;各个子应用项目的UI表现不一致&#xff0c;看了下式Vue项目滚动条和其他的子应用项目表现明显不一致。 有时候…

《网络安全0-100》网络安全前沿

1-人工智能和网络安全 人工智能和网络安全是两个不同的领域&#xff0c;但它 们之间存在着千丝万缕的联系和相互影响。下 面是一些人工智能和网络安全的联系和应用&#xff1a; 威胁检测和预测&#xff1a;人工智能可以利用机器学习 和深度学习等技术&#xff0c;对网络数据…

Golang每日一练(leetDay0103) 区域和检索1~3 Range Sum Query

目录 303. 区域和检索 - 数组不可变 Range Sum Query Immutable &#x1f31f; 304. 二维区域和检索 - 矩阵不可变 Range Sum Query 2d Immutable &#x1f31f;&#x1f31f; 307. 区域和检索 - 数组可修改 Range Sum Query Mutable &#x1f31f;&#x1f31f; &#…

kali配置静态IP地址

修改网络配置 执行命令&#xff1a; vim /etc/network/interfaces 文件末尾添加如下内容&#xff1a; auto eth0 iface eth0 inet static address 192.168.133.66 netmask 255.255.255.0 gateway 192.168.133.2其中&#xff0c;iface eth0 inet static 指配置eth0使用静态ip…

chatgpt赋能python:Python数据建模:从数据预处理到机器学习建模

Python数据建模&#xff1a;从数据预处理到机器学习建模 Python已经成为了数据建模与分析的主要工具之一&#xff0c;因为它的语法简单易懂&#xff0c;有许多数据科学库可以使用&#xff0c;支持各种各样的数据预处理和建模技术。在本文中&#xff0c;我们将重点介绍使用Pyth…

十五周算法训练营——普通动态规划(下)

今天是十五周算法训练营的第十二周&#xff0c;主要讲普通动态规划&#xff08;下&#xff09;专题。&#xff08;欢迎加入十五周算法训练营&#xff0c;与小伙伴一起卷算法&#xff09; 最长递增子序列 给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。…

基于Java网上医院预约挂号系统设计实现(源码+lw+部署文档+讲解等)

博主介绍&#xff1a; ✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战 ✌ &#x1f345; 文末获取源码联系 &#x1f345; &#x1f447;&#x1f3fb; 精…

Java:不支持发行版本5

错误 Java&#xff1a;不支持发行版本5 详细错误 同学在github上找到一个微服务项目&#xff08;基于maven进行构建&#xff09;&#xff0c;进行二开&#xff0c;导入项目运行控制台报错 Java&#xff1a;不支持发行版本5&#xff0c;笔者修改项目结构&#xff08; F i l e…

chatgpt赋能python:使用Python自动备份数据库

使用Python自动备份数据库 数据库是企业中非常重要的组成部分&#xff0c;里面存储着大量的数据和业务逻辑。为了避免数据库丢失或损坏可能带来的灾难性后果&#xff0c;我们通常需要定期备份数据库。而使用Python自动备份数据库是一种快捷高效的方式&#xff0c;今天我们将介…

基于Java助学贷款系统设计实现(源码+lw+部署文档+讲解等)

博主介绍&#xff1a; ✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战 ✌ &#x1f345; 文末获取源码联系 &#x1f345; &#x1f447;&#x1f3fb; 精…

chatgpt赋能python:Python数据库备份脚本

Python数据库备份脚本 数据库备份是保障数据安全的重要手段。Python作为一种简单易学、高效稳定的编程语言&#xff0c;被广泛应用于数据库备份脚本的编写。本文将介绍如何使用Python编写一个简单的数据库备份脚本。 准备工作 在开始编写脚本之前&#xff0c;需要安装Python…

读发布!设计与部署稳定的分布式系统(第2版)笔记07_线程阻塞

1. 通过增加复杂性解决一个问题&#xff0c;会产生全新系统失效方式的风险 2. 多线程技术使应用程序服务器具有足够的容量扩展能力&#xff0c;来满足Web上最大站点的需求 2.1. 产生并发错误的可能性 3. 服务器的进程正在运行 3.1. 并不能帮助用户完成工作 3.2. 模拟客户端…

RK3588平台开发系列讲解(导读篇)旗舰芯片RK3588介绍

平台内核版本安卓版本RK3588Linux 5.10Android 12文章目录 一、 视频了解二、特性说明三、性能比较沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇将介绍旗舰芯片RK3588。 自瑞芯微RK3588最初的发布时间已经过去了两年多,如今RK3588终于进入了落地阶段,搭载RK3…