时间复杂度 た 入场券 2022-08-28 13:55 182阅读 0赞 ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 1] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 2] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 3] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 4] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 5] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 6] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 7] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 8] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 9] ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 10] 1.我们知道常数项对函数的增长速度影响并不大,所以当 T(n) = c,c 为一个常数的时候,我们说这个算法的时间复杂度为 O(1); 如果 T(n) 不等于一个常数项时,直接将常数项省略。 比如 第一个 Hello, World 的例子中 T(n) = 2,所以我们说那个函数(算法)的时间复杂度为 O(1)。 T(n) = n + 29,此时时间复杂度为 O(n)。 2.我们知道高次项对于函数的增长速度的影响是最大的。n^3 的增长速度是远超 n^2 的,同时 n^2 的增长速度是远超 n 的。 同时因为要求的精度不高,所以我们直接忽略低此项。 比如 T(n) = n^3 + n^2 + 29,此时时间复杂度为 O(n^3)。 3.因为函数的阶数对函数的增长速度的影响是最显著的,所以我们忽略与最高阶相乘的常数。 比如 T(n) = 3n^3,此时时间复杂度为 O(n^3)。 综合起来:如果一个算法的执行次数是 T(n),那么只保留最高次项,同时忽略最高项的系数后得到函数 f(n),此时算法的时间复杂度就是 O(f(n))。为了方便描述,下文称此为 大O推导法。 由此可见,由执行次数 T(n) 得到时间复杂度并不困难,很多时候困难的是从算法通过分析和数学运算得到 T(n)。对此,提供下列四个便利的法则,这些法则都是可以简单推导出来的,总结出来以便提高效率。 **对于一个循环,假设循环体的时间复杂度为 O(n),循环次数为 m,则这个 循环的时间复杂度为 O(n×m)。** void aFunc(int n) { for(int i = 0; i < n; i++) { // 循环次数为 n printf("Hello, World!\n"); // 循环体时间复杂度为 O(1) } } 此时时间复杂度为 O(n × 1),即 O(n)。 **对于多个循环,假设循环体的时间复杂度为 O(n),各个循环的循环次数分别是a, b, c…,则这个循环的时间复杂度为 O(n×a×b×c…)。分析的时候应该由里向外分析这些循环。** void aFunc(int n) { for(int i = 0; i < n; i++) { // 循环次数为 n for(int j = 0; j < n; j++) { // 循环次数为 n printf("Hello, World!\n"); // 循环体时间复杂度为 O(1) } } } 此时时间复杂度为 O(n × n × 1),即 O(n^2)。 **对于顺序执行的语句或者算法,总的时间复杂度等于其中最大的时间复杂度。** void aFunc(int n) { // 第一部分时间复杂度为 O(n^2) for(int i = 0; i < n; i++) { for(int j = 0; j < n; j++) { printf("Hello, World!\n"); } } // 第二部分时间复杂度为 O(n) for(int j = 0; j < n; j++) { printf("Hello, World!\n"); } } 此时时间复杂度为 max(O(n^2), O(n)),即 O(n^2)。 **对于条件判断语句,总的时间复杂度等于其中 时间复杂度最大的路径 的时间复杂度。** void aFunc(int n) { if (n >= 0) { // 第一条路径时间复杂度为 O(n^2) for(int i = 0; i < n; i++) { for(int j = 0; j < n; j++) { printf("输入数据大于等于零\n"); } } } else { // 第二条路径时间复杂度为 O(n) for(int j = 0; j < n; j++) { printf("输入数据小于零\n"); } } } 此时时间复杂度为 max(O(n^2), O(n)),即 O(n^2)。 **时间复杂度分析的基本策略是:从内向外分析,从最深层开始分析。如果遇到函数调用,要深入函数进行分析。** [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16]: /images/20220828/faa98c3bd8c54470b753ac0992327ae8.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 1]: /images/20220828/0e1b4cf449c24b7ca2c11cd724b2c077.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 2]: /images/20220828/477da4dd2a06431b9c706c877817d8c8.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 3]: /images/20220828/8943679e673e4895b6ac5e88183e7a72.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 4]: /images/20220828/cd8890e1eadd439caebe2e40d549c89b.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 5]: /images/20220828/0a9be043125e4d7995f55520bc927560.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 6]: /images/20220828/50e682b5e77644c68597913f13317bb5.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 7]: /images/20220828/a0cd1165b137472fb0623539d11b8f6d.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 8]: /images/20220828/a367f5ab5d954dd899af8524e92efd0f.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 9]: /images/20220828/ca1c358815e641bb9c92aeb31445db8a.png [watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_size_20_color_FFFFFF_t_70_g_se_x_16 10]: /images/20220828/345627ad1d6b44f583d6ef0490ca5412.png
相关 时间复杂度 **时间复杂度** **一、时间复杂度的定义** 一般情况下,算法中基本操作重复执行的次数是问题规模n的某个函数,用T(n)表示,若有某个辅助函... 以你之姓@/ 2024年04月18日 11:04/ 0 赞/ 82 阅读
相关 搞懂时间复杂度、时间复杂度 文章目录 写在前面 1、数学中的log什么意思? 2、时间复杂度 2.1、用T(n)表示程序执行次数 末蓝、/ 2023年10月08日 12:48/ 0 赞/ 59 阅读
相关 时间复杂度_空间复杂度 时间复杂度\_空间复杂度 主要说明以下3点: 1.算法效率 2.时间复杂度 3.空间复杂度 一、算法效率 算法效率分析分为两种:第一种是时间效率,第二种 朱雀/ 2023年06月29日 15:59/ 0 赞/ 184 阅读
相关 时间复杂度 转载自:[https://blog.csdn.net/itachi85/article/details/54882603][https_blog.csdn.net_itach 约定不等于承诺〃/ 2022年12月26日 08:10/ 0 赞/ 248 阅读
相关 时间复杂度 常见的时间复杂度 <table> <thead> <tr> <th>复杂度名称</th> <th>具体表示</th> </tr> </ 叁歲伎倆/ 2022年12月04日 01:11/ 0 赞/ 222 阅读
相关 时间复杂度 几种排序算法的思想很容易掌握,就是对应的时间复杂度,究其原因就是对时间复杂度是什么,如何定义计算还不知道,那么时间复杂度是如何计算的呢?请看下文。 在说 £神魔★判官ぃ/ 2022年09月17日 12:26/ 0 赞/ 214 阅读
相关 时间复杂度 ![在这里插入图片描述][watermark_type_ZHJvaWRzYW5zZmFsbGJhY2s_shadow_50_text_Q1NETiBAenl5MTMwOTg4_ た 入场券/ 2022年08月28日 13:55/ 0 赞/ 183 阅读
相关 时间复杂度 时间复杂度 1. 概念 用来表示一个算法的理论上的耗时时间 2. 时间频度 一个算法中,语句执行的次数,被称为时间频度T(n) 3.时间复杂度 存在 蔚落/ 2022年03月21日 09:31/ 0 赞/ 273 阅读
相关 时间复杂度?? O(1) < O(log n) < O(n) < O(nlog n)< O(n^2) < O(n^3) < O(2^n) < O(n!) < O(n^n) 时间复杂度 傷城~/ 2021年10月01日 04:02/ 0 赞/ 410 阅读
相关 时间复杂度 什么是时间复杂度 > 算法的时间复杂度是一个函数,它定性描述该算法的运行时间。这是一个代表算法输入值的字符串的长度的函数。时间复杂度常用大O符号表述,不包括这个函 喜欢ヅ旅行/ 2021年06月10日 20:40/ 0 赞/ 509 阅读
还没有评论,来说两句吧...