day 11 算法的时间空间复杂度
(1).有以下程序:
求输入的n值(除1和n)之外的所有因子之和。

分析:这里函数内的循环体i初值不能为零。%是表示“取余”,0除以任何数都不会存在余数的,所有是余数为0.
(2).有以下程序:
形参m(2<=m<=9),在二维数组中存放一张m行m列的表格,有main函数输出
规则如下,使得每一列的数据以每一行首个数字为公差进行递增。

分析:主要就是输出显示二维数组,根据输入n的多少,来执行几行几列。

(3).有以下程序:
将长整型数中每一位上为偶数的数一次逆向取出,构成一个新数,高位在地位,地位在高位。
eg:25846513——————>输出:6482

分析:*t = d*k + *t;····>第一遍写的时候出错,忘记了传过来的是地址,应该解应用操作。这个错误经常考,不易发现。

(4).下列数据结果中,属于非线性结构的是【C】
A.循环队列
B.带链队列
C.二叉树
D.带链栈
分析:常见的线性结构:一维数组(栈)、链表、队列
常见的非线性结构:数、森林、图
栈:先进后出
队列:先进先出
(5).有序线性链表进行二分查找的前提是该线性表必须是【有序存储的(二分法)】
(6).一棵二叉树的中序遍历结果为DBEAFC,前序遍历结果为ABDECF,则后序遍历结果为【DEBFCA】
前序遍历:先输出父结点,再遍历左子树和右子树。
中序遍历:先遍历左子树,在输出父节点,再遍历右子树。
后序遍历:先遍历左子树,在遍历右子树,最后输出父节点。
小结:看输出父节点的顺序,就确定是前序、中序还算后序。
(7).算法的空间复杂度是指【A】,算法的时间复杂度是指【E】。
A.算法在执行过程中所需要的计算机存储空间
B.算法所处理的数据量
C.算法程序中的语句或指令条纹
D.算法在执行过程中所需要的临时工作单元数
E.算法在运行过程中所需要的时间
算法复杂度的计算方法:
时间复杂度指算法运行需要的时间,一般将算法的基本运算执行次数作为时间复杂度的度量标准。

总执行次数=1+1+n+n+n*n+n*(n+1)=2n^2+2n+1次,T(n^2)=2*n^2+2*n+1.当n足够大时,运行时间取决于最高项。因此后面可以忽略不计,舍小项,舍系数。即用时间复杂度的渐进上界O表示,那么该算法的时间复杂度为O(n^2)。【循环体最内部的循环次数往往是最多的!】
所以:对于一个算法,往往考察最坏的情况是怎样的,而不是考察最好的情况,最坏的情况对于衡量算法的好坏具有实际意义。
空间复杂度的计算方法:
空间复杂度是指在运行过程中占用了多少的存储空间,算法占用的存储空间包括:输入输出数据、算法本身、额外需要的辅助空间。
输入输出空间是必须的,算法的占用空间可以通过代码的精简来减免,而在运行是使用的辅助空间,是衡量空间复杂度的关键因素,一般将算法的辅助空间作为衡量空间复杂度的标准。

该算法使用了一个辅助空间,即空间复杂度为O(1)
day 11 算法的时间空间复杂度的更多相关文章
- 二叉树遍历问题、时间空间复杂度、淘汰策略算法、lru数据结构、动态规划贪心算法
二叉树的前序遍历.中序遍历.后序遍历 前序遍历 遍历顺序规则为[根左右] ABCDEFGHK 中序遍历 遍历顺序规则为[左根右] BDCAEHGKF 后序遍历 遍历顺序规则为[左右根] DCBHKGF ...
- 【C++】四种排序算法的时间比较
四种排序算法的时间比较 [注]clock函数对输入(用户输入)元素N排序的计时 #include<iostream> #include<time.h> using namesp ...
- 算法时间复杂度、空间复杂度(大O表示法)
什么是算法? 计算机是人的大脑的延伸,它的存在主要是为了帮助我们解决问题. 而算法在计算机领域中就是为了解决问题而指定的一系列简单的指令集合.不同的算法需要不同的资源,例如:执行时间或消耗内存. 如果 ...
- Python(算法)-时间复杂度和空间复杂度
时间复杂度 算法的时间复杂度是一个函数,它定量描述了该算法的运行时间,时间复杂度常用“O”表述,使用这种方式时,时间复杂度可被称为是渐近的,它考察当输入值大小趋近无穷时的情况 时间复杂度是用来估计算法 ...
- MOD 10,11算法(GB/T 17710-1999 数据处理 校验码系统 )的 Python实现
以上是算法简要说明,以下代码为Python实现,不过注意代码中的N=15,不是16. # GB/T 17710 双模校验算法 # QQ 3257132998 def GB_Code(str): str ...
- hiho一下 第四十八周 拓扑排序·二【拓扑排序的应用 + 静态数组 + 拓扑排序算法的时间优化】
题目1 : 拓扑排序·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho所在学校的校园网被黑客入侵并投放了病毒.这事在校内BBS上立刻引起了大家的讨论,当 ...
- SLAM: 图像角点检测的Fast算法(时间阈值实验)
作为角点检测的一种快速方法,FastCornerDetect算法比Harris方法.SIft方法都要快一些,应用于实时性要求较高的场合,可以直接应用于SLAM的随机匹配过程.算法来源于2006年的Ed ...
- [游戏模版11] Win32 动画 时间消息
>_<:This time we will study a new way to operate your picture.That is running your picture by ...
- MOD 10,11算法(GB/T 17710-1999 数据处理 校验码系统 ),使用javascript实现
原文链接:http://chunniu.info/p/74.html GB/T 17710-1999 数据处理 校验码系统 ,便于使用,使用javascript做了一个页面 [php] var NUM ...
随机推荐
- 使用Azure Functions & .NET Core快速构建Serverless应用
Code Repo: https://github.com/Asinta/ServerlessApp_NetconfChina2020 Prerequisites Visual Studio Code ...
- CF688B Lovely Palindromes 题解
Content 输入一个数 \(n\),输出第 \(n\) 个偶数位回文数. 数据范围:\(1\leqslant n\leqslant 10^{10^5}\). Solution 一看这吓人的数据范围 ...
- LuoguP7505 「Wdsr-2.5」小小的埴轮兵团 题解
Content 给出一个范围为 \([-k,k]\) 的数轴,数轴上有 \(n\) 个点,第 \(i\) 个点的位置为 \(a_i\).有 \(m\) 次操作,有且仅有以下三种: 1 x:所有点往右移 ...
- JS使用html()获取html代码获取不到input、textarea控件填写的值
我们可以重写一个方法 (function ($) { var oldHTML = $.fn.html; $.fn.formhtml = function () { if (arguments.leng ...
- JAVA获取当前日期的下周一到下周日的所有日期集合
/** * 获取当前日期的下周一到下周日的所有日期集合 * @return */ public static List getNextWeekDateList(){ Calendar cal1 = C ...
- 一个c++11自定义的信号量
1.关于 This is from here But I did some changes. 2. semaphore.h /** @ brief : this is from https://sta ...
- 【LeetCode】835. Image Overlap 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- 记录一次线上OOM调优经历
现状: k8s 的一个pod 有32G内存,每秒产生新对象的峰值在900Mb ---- 1900Mb(根据jstat计算Eden区获得) . 修改之前的参数 就一个命令行参数是-Xmx31g; 我修改 ...
- CoGAN
目录 概 主要内容 代码 Liu M., Tuzel O. Coupled Generative Adversarial Networks. NIPS, 2016. 概 用GAN和数据(从边缘分布中采 ...
- [高数]高数部分-Part II 导数与微分
Part II 导数与微分 回到总目录 Part II 导数与微分 一元函数微分的定义 一元函数定义注意点 基本求导公式 基本求导方法 复合函数求导 隐函数求导 对数求导法 反函数求导 参数方程求导 ...