首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏Zeusro

    时间序列复杂度

    传统时间空间复杂度 时间复杂度(Time Complexity)描述的是:算法执行所需的时间与输入规模之间的关系。 时间序列复杂度 时间序列复杂度(Time Series Complexity)描述的是:在满足时间复杂度以及空间复杂度的前置性论述下,算法执行的实际时间以及内存资源的利用效率。 时间序列复杂度是一个二维图表。X轴是t,Y轴是(used - buff/cache) / total 时间序列复杂度需要对程序进行可观测性分析。个人比较喜欢指数衰减型。 具体例子 时间序列复杂度的这一概念,破除了传统时间空间算法复杂度的浅层优劣问题。说点人话,你可以用一个看起来很傻的程序去模拟AI,只要这个“AI”能骗到人(通过图灵测试)。 因此,通过蜉蝣交配这个非常简单的例子,就能解答“时间序列复杂度”这一概念。 拓展 纵轴可以换成单位能耗指标,用来建设节能型智慧建筑。 与其说纵轴是内存利用率,不如说纵轴表示一种资源的利用效率。

    37520编辑于 2025-09-08
  • 来自专栏AI粉嫩特攻队

    用python做时间序列预测七:时间序列复杂度量化

    本文介绍一种方法,帮助我们了解一个时间序列是否可以预测,或者说了解可预测能力有多强。 而实际上A总是小于等于B的,所以A/B越接近1,预测难度越小,直觉上理解,应该就是波形前后部分之间的变化不大,那么整个时间序列的波动相对来说会比较纯(这也是熵的含义,熵越小,信息越纯,熵越大,信息越混乱 ),或者说会具有一定的规律,而如果A和B相差很大,则时间序列波动不纯,或者说几乎没有规律可言。 python实现 def SampEn(U, m, r): """ 用于量化时间序列的可预测性 :param U: 时间序列 :param m: 模板向量维数 : param r: 距离容忍度,一般取0.1~0.25倍的时间序列标准差,也可以理解为相似度的度量阈值 :return: 返回一个-np.log(A/B),该值越小预测难度越小 """

    2.4K10发布于 2020-06-11
  • 来自专栏全栈程序员必看

    解惑3时间频度,算法时间复杂度

    例如,如果一个算法对于任何大小为 n (必须比 n0 大)的输入,它至多需要 5n3 + 3n 的时间运行完毕,那么它的渐近时间复杂度是 O(n3). 而n^3+5n 和 6n^3+4n ,执行曲线分离,说明多少次方式关键 三、时间复杂度 我们现在理解了时间频度的T(n)的含义,假设当有一个辅助函数f(n),使得当n趋近无穷大时,T(n)/f(n)的极限值为不等于 又根据时间频度T(n)的“三个忽略”原则,我们可以知道时间复杂度是这样得到的: 忽略所有常数 只保留函数中的最高阶项 去掉最高阶项的系数 举个例子: 某算法T(n)=2n^3+4n-5,按步骤走: T( n)=2n^3+4n T(n)=2n^3 T(n)=n^3 即可得该算法时间复杂度为O(n^3) 四、常见时间复杂度 这里按复杂度从低到高列举常见的时间复杂度: 常数阶O(1) // 无论代码执行了多少行 最好情况时间复杂度:代码在最坏情况下执行的时间复杂度

    1.1K20编辑于 2022-09-23
  • 来自专栏python数据分析实践

    Matplotlib时间序列型图表(3

    例如计算2020-3-19日1017A站点的浓度百分比,应该是在2020-3-19这一天1017A站点浓度除以该日所有站点的浓度和。 (lambda x: x/unstack_df2, axis = 0) #根据行总和计算每一日每个站点占该日的百分比 mean = unstack_df3.apply(lambda x: x.mean( ), axis = 0).sort_values(ascending = False) #4个站点全年的平均占比,从大到小排列 new_df = unstack_df3[mean.index] #将unstack_df3 按照大小排序好的序列排列 2、绘图 fig = plt.figure(figsize = (5, 5)) ax1 = fig.add_subplot() ax1.stackplot(new_df.index 3.

    59620编辑于 2023-02-23
  • 来自专栏前端学习文档

    时间复杂度

    什么是时间复杂度? 定性描述该算法的运行时间,一个函数、用大 O 表示,例如 O (1)、 O (n)、O (logN) ... (2 ^ n) 上面从上至下依次的时间复杂度越来越大,执行的效率越来越低。 javascript for (let i = 0; i < n; i++) { console.log(i) } O(1) + O(n) = O(n) 当两个时间复杂度的代码在一块时,以时间复杂度较大的为准 ,得到的结果就是真实的时间复杂度。 当时间复杂度进行相加时,却可以忽略不计。

    50400编辑于 2023-06-08
  • 来自专栏Python碎片公众号的专栏

    时间复杂度

    顺序结构的代码,时间复杂度按加法进行计算,时间复杂度为每行顺序执行的代码的时间复杂度相加。 3. 循环结构的代码,时间复杂度按乘法进行计算,时间复杂度为每一层循环结构的时间复杂度相乘。 如下面的代码,整体是一个循环结构的代码,在最内层循环中,前两行代码都会做一次字符串拼接和一次打印,第三行代码会做一次乘法运算、一次字符串拼接和一次打印,三行代码的时间复杂度依次为2,2,3。 这三行代码是顺序结构,所以三行代码的时间复杂度为2+2+3=7。 根据大O记法,若程序执行次数为一个常数,则时间复杂度为一个O(1)。若程序执行次数为问题规模n的一次函数,如T(n)=3n+20和T(n)=5n+8,则时间复杂度都为O(n)。 常见的时间复杂度比较如下: O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(n^3) < O(2^n) < O(n!) < O(n^n) ?

    1.1K20发布于 2021-02-26
  • 来自专栏从码农的全世界路过

    时间复杂度

    今天用10分钟的时间,介绍下算法中最基本的一个概念,时间复杂度. 简单来说,就是一个算法,后者一个方法或者函数,执行时需要多长时间. CPU执行每条语句的真正时间忽略为1, 所用时间就是T(n)=1 + N + N = 2 * N + 1 根据时间复杂度的基本规则:去掉常数,保留最高阶 最后结果为T(N)=O(2 * N + 1) = O(N) 也因为上述规则,时间复杂度,也称为渐进的时间复杂度. O(2^N) 下面是常用的时间复杂度表达式和术语, 阶 对应术语 1 O(1) 常数阶 2 O(N) 线性阶 3 O(N^2) 平方阶 4 O(logN) 对数阶 5 O(NlogN) NlogN 阶 6 O(N^3) 立方阶 7 O(2^N) 指数阶 以上,简单的介绍了时间复杂度的相关概念和算法.

    67700编辑于 2022-06-20
  • 来自专栏Android 进阶

    时间复杂度

    常见的算法时间复杂度 时间复杂度与空间复杂度区别 时间复杂度:全称渐进式时间复杂度,表示算法的执行时间与数据规模的增长关系; 空间复杂度:全称渐进式空间复杂度,表示算法的存储空间与数据规模增长关系; /*执行了一次*/ i=n/2+n;              /*执行了一次*/ printf("i=%d",i);     /*执行了一次*/ 非常容易分析出这段代码一共执行了3次 ,那么时间复杂度就是O(3)吗,这样想是错误的,回头看之前计算时间复杂度方法,它是f(n)=3,所以应该把3改为1,即O(1)。 平均时间复杂度:全称叫加权平均时间复杂度或者期望时间复杂度。 而且,在能够应用均摊时间复杂度分析的场合,一般均摊时间复杂度就等于最好情况时间复杂度。均摊时间复杂度就是一种特殊的平均时间复杂度

    1K20发布于 2019-12-26
  • 来自专栏沉默王二

    时间复杂度

    “二哥,为什么要讲时间复杂度呀?”三妹问。 “因为接下来要用到啊。 常见的时间复杂度有这么 3 个: 1)O(1) 代码的执行时间,和数据规模 n 没有多大关系。 比如说下面这段代码: int i = 0; int j = 0; int k = i + j; 实际上执行了 3 次,但我们也认为这段代码的时间复杂度为 O(1)。 2)O(n) 时间复杂度和数据规模 n 是线性关系。换句话说,数据规模增大 K 倍,代码执行的时间就大致增加 K 倍。 3)O(logn) 时间复杂度和数据规模 n 是对数关系。 k | i*2^k “好了,三妹,这节就讲到这吧,理解了上面 3时间复杂度,后面我们学习 ArrayList、LinkedList 的时候,两者在增删改查时的执行效率就很容易对比清楚了

    70450发布于 2021-09-03
  • 来自专栏张家辉的树屋

    时间复杂度

    比如 T(n) = n^3 + n^2 + 29,此时时间复杂度为 O(n^3)。 3、因为函数的阶数对函数的增长速度的影响是最显著的,所以我们忽略与最高阶相乘的常数。 比如 T(n) = 3n^3,此时时间复杂度为 O(n^3)。 } } } 复制代码 此时时间复杂度为 O(n × n × 1),即 O(n^2)。 3、对于顺序执行的语句或者算法,总的时间复杂度等于其中最大的时间复杂度。 } } 复制代码 此时时间复杂度为 max(O(n^2), O(n)),即 O(n^2)。 4、对于条件判断语句,总的时间复杂度等于其中 时间复杂度最大的路径 的时间复杂度。 所以该方法的时间复杂度可以表示为 O((5/3)^n),简化后为 O(2^n)。 可见这个方法所需的运行时间是以指数的速度增长的。

    75021发布于 2021-02-02
  • 来自专栏来自csdn的博客

    时间复杂度

    题目引入 让我们先来看一个简单的C语言程序,这个程序的功能是计算一个整数数组中所有元素的和: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 理解时间复杂度的计算方法和分析技巧,对于优化代码性能至关重要。 知识点分析 时间复杂度的定义 时间复杂度是衡量算法运行时间与输入规模之间关系的一个指标。 常见的时间复杂度 在C语言编程中,我们经常会遇到以下几种常见的时间复杂度: O(1):常数时间复杂度。表示算法的运行时间与输入规模无关,无论输入规模多大,运行时间都是常数级别的。 时间复杂度与空间复杂度的权衡 在优化时间复杂度时,我们可能会增加程序的空间复杂度。例如,使用哈希表可以实现O(1)时间的查找和插入操作,但需要额外的空间来存储哈希表。 在实际编程中,我们需要注意时间复杂度与实际运行时间的关系、时间复杂度的上界和下界、时间复杂度与空间复杂度的权衡以及时间复杂度的计算精度等问题。

    35400编辑于 2025-04-15
  • 来自专栏Howl同学的学习笔记

    时间复杂度

    在了解时间复杂度之前,先了解一下原操作和时间频度 ---- 一.原操作 原操作是指固有的数据类型的操作,可以理解为基本运算,下面的代码块中 3,6,7,9 都是原操作 例1 1. void foo (int a[],int n) 2. { 3. printf("%d",i+j); //即深层原操作次数为n^2+10n } } } 即 T(n) = n^2+10n 三.时间复杂度 O(n) 时间复杂度是用时间频度的最大数量级表示: O(n) = ( T(n)的数量级 ) 例2中,T(n) = n^2+10n,其最大数量级为 n^2 (即忽略其常数和低级次幂) 最后 O(n) = n^2 四.时间复杂度对照表 O(1) < O(log2 N) < O(n) < O(nlog2 N) < O(n^2) < O(n^3) < O(2^n) < O(n!)

    67520编辑于 2022-05-09
  • 来自专栏Android小知识

    时间复杂度

    什么是时间复杂度 时间复杂度是指程序执行的次数,可以用大写的字母O(次数)来表示,我们常见的时间复杂度可分为四种 常数:程序执行次数是固定值 线性:程序执行次数是n次 对数:程序执行次数是折半的可以记为 log以2为底n的对数 高阶:程序执行次数为循环n次 为什么使用时间复杂度 用于判断算法的优劣,空间复杂度 相同时算法所执行的时间越小,算法越优。 常见的时间复杂度种类 一般我们所说的时间复杂度不是指具体的程序执行次数,而是假设程序执行的次数无穷大时的时间复杂度。 常数:T(n)=O(1) 线性:T(n)=O(n) 对数:T(n)=O(log以2为底n的对数) 高阶:T(n)=O(n的整数次方) 只有常数量级,时间复杂度转化为1。

    79610发布于 2020-02-18
  • 来自专栏D·技术专栏

    时间复杂度

      之前认为时间复杂度就是程序执行的时间,百度上这么说的 算法的时间复杂度是一个函数,它定性描述该算法的运行时间 很多人包括我自己都有一个疑问,就是现在的计算机的硬件性能已经很强大了,所以对于性能或者说时间复杂度上还用关心吗 比如有这样一个例子,在一台很久的机器和一台处理性能高100倍的新机器,旧机器执行算法A时间复杂度为O(n),新机器执行算法B的时间复杂度为O(n2)。 T(n) = 10. 2、下面如果把10,换成变量n,则公式变为 T(n) = n. 3、再往下 for (int i = n; i > 1; i /= 2) { System.out.println ,有了渐进时间复杂度。 = logn 可以表示为O(logn) T(n) = n2 可以表示为 O(n2) O(1) < O(logn) < O(n) < O(n^2),当然除了这些还有更复杂的 O(nlogn)、O(n^3)

    86010发布于 2021-09-07
  • 来自专栏Linux网络:从不懂到不会

    时间复杂度

    1.1时间复杂度概念 其实就是一个函数式T(n),并非具体的运行时间,就算该算法的时间复杂度。 1.2大O的渐进表示法 计算时间复杂度就是利用大O的渐进表示法。 :O(N) 这个例子的执行次数:T(N)=2*N+M,显而易见2*N是对结果影响最大的一项,并且根据渐近法的第二条可得本例的时间复杂度。 例二:  void func3(int N,int M) { int count = 0; for (int i = 0; i < N; i++) { count++; } for count++; } } 时间复杂度:O(1) 这个例子的执行次数:T(N)=10,这个程序循环了10次,是一个具体的数字,故根据渐近法的第三条可得时间复杂度 例四: void func5(int

    10810编辑于 2026-01-12
  • 来自专栏软件工程

    时间复杂度

    也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出。 算法复杂度分为时间复杂度和空间复杂度。 其作用: 时间复杂度是指执行算法所需要的计算工作量; 空间复杂度是指执行这个算法所需要的内存空间。 常数时间的操作:一个操作如果和数据量没有关系,每次都是固定时间内完成的操作,叫做常数操作。 时间复杂度为一个算法流程中,常数操作数量的指标。常用O(读作big O)来表示。 4....+3+2+1)次,每次操作是一个常数时间操作记为O(1)(读作bigO(1)) 所以整个时间化简复杂度应该是(N^2 /2+N+1)*O(1),也就是(aN^2+bN+1)*O(1) image.png 这次算法时间复杂度应去掉低阶项bN+1和N的系数A f(N)=N^2, O(f(n))=O(N^2) 评价一个算法流程的好坏,先看时间复杂度的指标,然后再分析不同数据样本下的实际运行时间,也就是常数项时间

    63430编辑于 2022-05-13
  • 来自专栏C++/Linux

    时间复杂度空间复杂度

    时间复杂度 2.1 时间复杂度的概念 2.2 大O的渐进表示法 2.3 常见时间复杂度计算举例 3. 空间复杂度 4. 常见复杂度对比 5. 实例2: // 计算Func3时间复杂度? 当然,通过 比较M和N的大小 我们也可以将其细化: M>>N : O(M) N>>M : O(N) M与N差不多相同 : O(M)或O(N) 实例3: // 计算Func4的时间复杂度? 实例3: // 计算阶乘递归Fac的空间复杂度? 常见复杂度对比 一般算法常见的复杂度如下: 5201314 O(1) 常数阶 3n+4 O(n) 线性阶 3n^2+4n+5 O(n^2) 平方阶 3log(2)n+4 O(logn) 对数阶 2n+3nlog

    2K00编辑于 2023-03-28
  • 来自专栏数据STUDIO

    时间序列 | pandas时间序列基础

    时间序列(time series)数据是一种重要的结构化数据形式,应用于多个领域,包括金融学、经济学、生态学、神经科学、物理学等。在多个时间点观察或测量到的任何事物都可以形成一段时间序列。 很多时间序列是固定频率的,也就是说,数据点是根据某种规律定期出现的(比如每15秒、每5分钟、每月出现一次)。时间序列也可以是不定期的,没有固定的时间单位或单位之间的偏移量。 时间序列数据的意义取决于具体的应用场景,主要有以下几种: 时间戳(timestamp),特定的时刻。 固定时期(period),如2008年1月或2020年全年。 例如,我们可以将之前那个时间序列转换为一 个具有固定频率(每日)的时间序列,只需调用resample即可 ---- pandas.date_range() 生成日期范围 pandas.date_range 0.704732 2011-01-08 -1.502936 2011-01-10 NaN 2011-01-12 NaN dtype: float64 shift通常用于计算一个时间序列或多个时间序列

    2.2K30发布于 2021-06-24
  • 来自专栏机器学习/数据可视化

    python-for-data-3时间序列

    时间序列在很多的领域都是重要的结构化数据形式,例如经济学、金融、生态学、物理学等,其特点是: 在多个时间点进行了观测 许多时间序列是固定频率,即根据相同的规则定期出现 时间序列也可以是没有规则的 ? 时间序列的应用 时间戳 固定的时间区间 时间间隔 笔记1:最广泛和最简单的时间序列时间戳引起的 处理时间3大模块: datetime time calendar 下面? 详细介绍3大模块的使用 calendar 日历模块calendar中,常用的方法是 ? calendar calendar(year,w=2,l=1,c=6):返回year年的日历,3个月一行,间隔距离(每2个月的间隔,总共2个间隔)为c,每个宽度间隔w字符,每行长度:21*w+18(3* 到 31 3 tm_hour 0 到 23 4 tm_min 0 到 59 5 tm_sec 0 到 61 (60或61 是闰秒) 6 tm_wday 0到6 (0是周一) 7 tm_yday 1 到

    2.1K10发布于 2021-03-01
  • 来自专栏LittlePanger的代码之路

    时间复杂度与空间复杂度

    主要还是从算法所占用的「时间」和「空间」两个维度去考量。 时间维度:是指执行当前算法所消耗的时间,我们通常用「时间复杂度」来描述。 记作 T(n)= O( f(n) ),称O( f(n) ) 为算法的渐进时间复杂度,简称时间复杂度。 T(n) 不同,但时间复杂度可能相同。 如:T(n)=n²+7n+6 与 T(n)=3n²+2n+2 它们的 T(n) 不同,但时间复杂度相同,都为 O(n²)。 因此这个代码的时间复杂度为:O(log2n) 。 O(log2n) 的这个 2 时间上是根据代码变化的,若 i = i * 3 ,则是 O(log3n) 。 常见:二分查找 3. 立方阶 O(n^3) 3次n循环 7. k 次方阶 O(n^k) k次n循环 3 空间复杂度 类似于时间复杂度的讨论,一个算法的空间复杂度(Space Complexity)定义为该算法所耗费的存储空间

    1.1K30发布于 2020-04-14
领券