4.9-算法 4.10-伪代码 4.11复杂度 4.12排序

本文详细介绍了算法的基本概念,包括其五个特性:有穷性、可行性、确定性、输入和输出。接着,阐述了伪代码的定义及应用实例,作为一种介于自然语言和编程语言之间的描述方式。此外,深入探讨了复杂度的分类,特别是时间复杂度和空间复杂度,通过具体例子解释了如何分析和表示复杂度,并提到了排序算法的时间复杂度。最后,简要提及了空间复杂度的概念,即程序运行时所需临时存储空间的度量。
摘要由CSDN通过智能技术生成

一、算法

1、概念

  • 对特定问题求解的一种描述,是一个指定的、有序的序列(也就是说如何解答这个问题,第一步、第二步、第三步分别怎么做......);
  • 也可以简单理解为一个有序的指令序列用来求解一个特定的问题;

2、算法的5个特性

  • 有穷性:一个算法必须在有穷的时间之内完成;也就是求解的步骤是有限的,完成每一步的时间是有限的。
  • 可行性:一个算法是可行的;也就是针对特定问题的求解,能够在有限步,有限时间内完成。
  • 确定性:在算法中的指令序列,每一个指令都有确定的含义,不存在二义性。同一个条件里执行多次得到的结果都会是相同的输出。
  • 输入:一个算法可以有0~n个输入。
  • 输出一个算法一定有1~n个输出。

二、伪代码

1、概念

  • 介于自然语言和程序语言之间的,对算法实现的一种表现形式。

2、举例说明

三、复杂度

1、分类

  • 时间复杂度(考试重点)
  • 空间复杂度

2、时间复杂度

(1)概念

  • 是指程序从运行开始到结束所需要的时间。

(2)分析时间复杂度的方法

  • 从算法中取一种对于所研究问题来说基本的运算操作,以该操作的重复次数作为运算的时间度量。
  • 就是说在算法中看这个操作的重复程度叫做时间复杂度。

(3)举例说明时间复杂度

  • 例如1:下面的每条语句都只操作一遍,程序就运行结束了,那么该程序的时间复杂度就是O(1);
  • 例如2:for循环执行n次后才结束,所以这个程序的时间复杂度是O(n)。
  • 例如3:嵌套循环语句,因为i<n、j<n,所以c=c+1会循环n的平方次,所以这个程序的时间复杂度是O(n的平方)。

(4)三种记作方法

  • O(常考)
    • 上界,表示小于等于。
    • 定义一个函数g(n),O(g(n))表示对于f(n)存在一个正常数c和n,使得n>n0的时候,f(n)<=cg(n),也就是0<=f(n)<=cg(n),也就是说cg(n)是f(n)的上界。
  • Ω
    • 下界,表示大于等于。
    • 定义一个函数g(n),Ω(g(n))表示对于f(n)存在一个正常数c和n,使得n>n0的时候,f(n)>=cg(n),也就是f(n)>=cg(n)>=0,也就是说cg(n)是f(n)的下界。
  • Θ
    • 紧致界。
    • 定义一个函数g(n),Θ(g(n))表示对于f(n)存在两个正常数c1和c2(c2>c1),以及n,使得n>n0的时候,c2g(n)>=f(n)>=c1g(n),也就是说(c1g(n),c2g(n))是f(n)的紧致界。

(5)排序(常考)

重点记忆平均情况,适当记忆稳定性。
注意:考题中可能会log2也可能用lg10表示时间复杂度,不用纠结,他们之间相差的是一个常数倍,对于一个数量级来讲是可以忽略的。

3、空间复杂度

(1)概念

  • 指的是程序在运行过程中,需要临时占用存储空间大小的度量。
  • 一般来讲空间复杂度只考虑在运行过程中,给局部变量分配的存储空间的大小。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值