| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 21 11 11数据结构学习总结(时间复杂度与空间复杂度) -> 正文阅读 |
|
[数据结构与算法]21 11 11数据结构学习总结(时间复杂度与空间复杂度) |
一 时间复杂度 1.用常数1取代运行时间中的加法常数 2.在修改后的运行次数函数中,只保留最高阶项 3.如果最高阶项存在且不是1,则除去这个项目相乘的常数,得到的结果为大O阶
O(N+M)
O(1)
O(N*N)
O(N) 有些算法复杂度存在最好,平均,最差情况,此时按最差情况算 冒泡的时间复杂度为O(N*N)? (N为数字个数) 二分法查找的时间复杂度为0?? (N为数字个数) 常见的时间复杂度:O(N*N) O(N) O(logN) O(1) 二 空间复杂度 空间复杂度不计算空间,计算变量个数
O(1) 时间复杂度是累计的,空间复杂度不累计 循环走了n次,重复利用的是一个空间
O(N) 调用时建立栈帧,返回时销毁栈帧 三 复杂度在算法的意义 校园招聘的笔试算法题和面试中会考察对复杂度的计算和理解 例题: 数组nums包含0到n的所有整数,但缺了一个,请编写代码找出缺失的整数,在O(N)时间内完成: 思路一: 排序,时间复杂度不符合,最快O(N*logN) 思路二: 把0到N加到一起,计为ret1,再把数组中所有数加到一起,计为ret2,ret1-ret2就是我们要找的数
思路三: 数组中数依次与0--N中所有数异或,最后剩下的数据为缺少的数据
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 10:17:57- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |