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

Day2算法

Day2算法

1.算法的基本概念

算法:

对特定问题求解步骤的一种描述,他叔指令的有限序列,其中的每条指令表示一个或多个操作。

算法的特性:

1.有穷性:

一个算法必须总在执行有穷步之后结束,且每一步都可在有穷时间内完成。

算法必须是又穷的,程序可以是无穷的。

2.确定性:

算法中的每条指令必须有确切的含义,对于相同的输入只能得出相同的输出。

3.可行性

算法中描述的操作都可以通过已经实现的基本运算执行有限次来实现。

4.输入:

一个算法有零个或多个输入,这些输入取自于默写特定的对象的集合。

5.输出

一个算法有一个多个输出,这些输出是与输入有某种特定关系的量。

好的算法的特质:

1.正确性,

2.可读性

3.健壮性

4.高效率和低存储需求。(时间复杂度低,空间复杂度低)

算法的效率:

算法的时间复杂度:
void loveyou(int n){int i =1;while(i<n){i++;printf("I love you %d\n",i);}printf("I love you More than %d\n",n);}int main(){loveyou(3000);}

上述代码T(3000)=1+3001+2*3000+1,T(n)=3n+1;用O表示“同阶”,同等数量级。T(n)=O(n)。

可以简化。在数学中就是抓大头。(只考虑阶数高的部分)。

注意

O(1)<O(log2n)<O(n)<O(nlog2n)<O(n^2)<O(n^3)<O(2^n)<O(n!)<O(n^n) 口诀:常对幂指阶

最坏时间复杂度:

最坏情况下算法的时间复杂度。

平均时间复杂度:

所有输入示例等概率出现的情况下,算法的期望运行时间。

最好时间复杂度:

最好情况下算法的时间复杂度。

http://www.lryc.cn/news/463197.html

相关文章:

  • 智洋创新嵌入式面试题汇总及参考答案
  • 无线网卡知识的学习-- wireless基础知识(nl80211)
  • 除了 Python,还有哪些语言适合做爬虫?
  • JS | JS中类的 prototype 属性和__proto__属性
  • 15分钟学Go 第3天:编写第一个Go程序
  • 简单的常见 http 响应状态码
  • 2024年【安全员-C证】复审考试及安全员-C证模拟考试题
  • RT-Thread之STM32使用定时器实现输入捕获
  • 数字图像处理:图像分割应用
  • Java面试宝典-并发编程学习02
  • 【每日一题】洛谷 - 快速排序模板
  • Django模型优化
  • Python实现火柴人的设计与实现
  • 衡石分析平台系统分析人员手册-应用模版
  • Git和SVN
  • 【C语言教程】【常用类库】(十八)宏与预处理 - <stddef.h> 和 <stdbool.h>
  • 订单超时过期的实现方案的探讨
  • C++中的CRTP
  • go压缩的使用
  • 一图解千言,了解常见的流程图类型及其作用
  • 【微信小程序_19_自定义组件(1)】
  • 标准版admin后台页面添加及开发操作流程及注意事项
  • ‘perl‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件。
  • 如何利用CMMI帮助组织消除低价值流程
  • 如何理解线程安全这个概念?
  • 代码随想录算法训练营第48天| 739. 每日温度,496.下一个更大元素 I,503.下一个更大元素II
  • Qt 支持打包成安卓
  • PDF工具类源码
  • NirCmd-Gui-Chinese-Introduction
  • 吴恩达深度学习笔记(7)