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

暑期数据结构 时间复杂度

有任何不懂的问题可以评论区留言,能力范围内都会一一回答

时间复杂度的定义:

在计算机科学中,算法的时间复杂度是一个函数,它定量描述了该算法的运行时间。

一个算法执行所耗费的时间,从理论上说,是不能算出来的,只有你把你的程序放在机器上跑起来,才能知道。

但是我们需要每个算法都上机测试吗?是可以都上机测试,但是这很麻烦,所以才有了时间复杂度这个分析方式。个算法所花费的时间与其中语句的执行次数成正比例,算法中的基本操作的执行次数,为算法的时间复杂度。


即:找到某条基本语句与问题规模N之间的数学表达式
就是算出了该算法的时间复杂度。

我们直接上几道例题去感受一下

void Function(int n) {int count = 0;for (int i = 0; i < n; ++i){for (int j = 0; j < n; j++){++count;}}for (int k = 0; k < 2 * n; ++k){++count;
}int m = 10;while (m--){count++;}
}

我们先看看这个函数function执行的基本操作次数是一个和n有关的函数

很明显这个函数是f(n)=n*n+2*n+10

但是实际中我们计算时间复杂度时,我们其实并不一定要计算精度的执行次数,而只需要大概执行次数,那么这里我们使用O的渐进表示法

大O的渐进表示法
大O符号:是用于描述函数渐进行为的数学符号。
推导大O阶方法:
1、用常数1取代运行时间中的所有加法常数。
2、在修改后的运行次数函数中,只保留最高阶项。
3、如果最高阶项存在且不是1,则去除与这个项目相乘的常数。得到的结果就是大O阶。
使用大O的渐进表示法以后,Func1的时间复杂度为:

O(N2)
·N=10 F(N)=100
·N=100 F(N)=10000
·N=1000 F(N)=1000000
通过上面我们会发现大O的渐进表示法去掉了那些对结果影响不大的项,简洁明了的表示出了执行次数。另外有些算法的时间复杂度存在最好、平均和最坏情况:
最坏情况:任意输入规模的最大运行次数(上界)
平均情况:任意输入规模的期望运行次数
最好情况:任意输入规模的最小运行次数(下界)
例如:在一个长度为N数组中搜索一个数据x
最好情况:1次找到
最坏情况:N次找到
平均情况:N/2次找到
在实际中一般情况关注的是算法的最坏运行情况,所以数组中搜索数据时间复杂度为O(N)

比如说如果函数是F(N)=N+4,那么当N无限大的时候,对F(N)产生主要影响的是N

因此此时O(N)的值是N

比如说如果函数是F(N)=N*N+N+4,那么当N无限大的时候,对F(N)产生主要影响的是N*N

因此此时O(N)的值是N*N

但是有种情况下需要注意

log 2 n 这种对数计算机很难打出来

因此有且仅有在表示时间复杂度是log 2 N可以直接写成logN(仅仅限于以二为底

最后留给大家一个题目 其实本质上是一个数学题

long long Fib(int N)
{if (N < 3)return 1;return Fib(N - 1) + Fib(N - 2);
}

思考一下,这个函数执行的基本操作次数是一个和n有关的函数

这个函数表达式是啥

提示:这个题本质上是一个斐波那契数列的题目

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • C#获取Network的相关信息
  • 招聘求职小程序
  • github技巧和bug解决方法短篇收集
  • 【Impala】学习笔记
  • Android之复制文本(TextView)剪贴板
  • 【docker快捷部署系列一】docker快速入门,安装docker,解决运行Docker Quickstart Terminal出错
  • 9、阿里云 Ubuntu22.04、安装docker、mysql、mongodb
  • JVM知识总结(类加载器)
  • 医疗大健康解决方案HIS方案
  • C# Unity 面向对象补全计划 七大原则 之 迪米特法则(Law Of Demeter )难度:☆☆☆ 总结:直取蜀汉
  • MongoDB的复合通配符索引详解
  • ulimit
  • ShardingSphere之ShardingProxy集群部署
  • C# 在Word中插入或删除分节符
  • 创建一个简单的贪吃蛇游戏:HTML、CSS和JavaScript教程
  • [ 一起学React系列 -- 8 ] React中的文件上传
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • CSS相对定位
  • el-input获取焦点 input输入框为空时高亮 el-input值非法时
  • es6--symbol
  • GitUp, 你不可错过的秀外慧中的git工具
  • interface和setter,getter
  • JavaScript设计模式与开发实践系列之策略模式
  • markdown编辑器简评
  • mongodb--安装和初步使用教程
  • PHP那些事儿
  • Python代码面试必读 - Data Structures and Algorithms in Python
  • React-flux杂记
  • Webpack 4x 之路 ( 四 )
  • 百度贴吧爬虫node+vue baidu_tieba_crawler
  • 飞驰在Mesos的涡轮引擎上
  • 前端代码风格自动化系列(二)之Commitlint
  • 思维导图—你不知道的JavaScript中卷
  • 原生 js 实现移动端 Touch 滑动反弹
  • 在electron中实现跨域请求,无需更改服务器端设置
  • 自动记录MySQL慢查询快照脚本
  • linux 淘宝开源监控工具tsar
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • #控制台大学课堂点名问题_课堂随机点名
  • (delphi11最新学习资料) Object Pascal 学习笔记---第7章第3节(封装和窗体)
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • (Matalb分类预测)GA-BP遗传算法优化BP神经网络的多维分类预测
  • (编译到47%失败)to be deleted
  • (动态规划)5. 最长回文子串 java解决
  • (附源码)计算机毕业设计ssm高校《大学语文》课程作业在线管理系统
  • (回溯) LeetCode 131. 分割回文串
  • (深度全面解析)ChatGPT的重大更新给创业者带来了哪些红利机会
  • (十六)Flask之蓝图
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • .NET 某和OA办公系统全局绕过漏洞分析
  • .net/c# memcached 获取所有缓存键(keys)
  • .netcore 获取appsettings
  • .net的socket示例
  • .NET企业级应用架构设计系列之开场白
  • @ 代码随想录算法训练营第8周(C语言)|Day57(动态规划)