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

【算法】入门详解

1. 算法效率

时间复杂度:一个算法所花费的时间与其中语句的执行次数成正比,所以算法中的基本操作的执行次数,为算法的时间复杂度。

空间复杂度:主要衡量一个算法运行所需要的额外空间

1.1 时间复杂度

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

举例1:计算fun1中++count语句总共执行了多少次

 void Func1(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; 
     }
     printf("%d\n", count);
 }

答:N^2+2N+10

1.1.1 大O渐进表示法 (估算)

大O符号 (Big O notation):用于描述函数渐近行为的数学符号

推导大O阶的方法:

  1. 用常数1取代运行时间中的所有加法常数
  2. 在修改后的运行次数函数中,只保留最高项
  3. 如果最高阶项存在且系数不是1,则去除与这个项相乘的系数,得到的结果就是大O阶

1.1中举例1使用大O的渐近表示法后,时间复杂度为O(N^2)

另外有些算法的时间复杂度存在最好,平均和最坏情况:

比如冒泡排序中,最好的情况是1,平均情况是N/2,最坏情况是N。

1.1.2 时间复杂度计算举例

1.1.2.1 O(N)
 void Func2(int N) 
 {
   
      int count = 0;
      for (int k = 0; k < 2 * N ; ++ k)
      {
   
         ++count;
      }
      int M = 10;
      while (M--)
      {
   
         ++count;
      }
      printf("%d\n", count);
 }

结果:2N+10,表示为N(0)

1.1.2.2 O(M + N)
 void Func3(int N, int M)
 {
   
     int count = 0;
     for (int k = 0; k < M; ++ k)
     {
   
         ++count;
     }
     for (int k = 0; k < N ; ++ k)
     {
   
         ++count;
     }
     printf("%d\n", count);
 }

结果:M + N,表示为O(M + N)

1.1.2.3 O(1)
 void Func4(int N) 
 {
   
     int count = 0;
     for (int k = 0; k < 100; ++k)
     {
   
         ++count;
     }
      printf("%d\n", count);
  }

结果:100,表示为O(1)

1.1.2.4 O(N^2)
 void BubbleSort(int* a, int n) 
 

相关文章:

  • asp.net mvc 向前端响应json数据。用到jquery
  • 描述@keyframes规则在 CSS 动画中的原理及作用,如何创建一个简单的动画
  • 大厂技术博客总结
  • MySQL 5.7升级8.0报异常:ONLY_FULL_GROUP_BY
  • 猿大师中间件:如何在最新Chrome浏览器Web网页内嵌本地OCX控件?
  • Docker学习笔记(十二)docker镜像没有vi怎么优雅的编辑文本
  • FAQ - VMware vSphere Web 控制台中鼠标控制不了怎么办?
  • Cursor学习总结
  • 正则表达式基本语法和Java中的简单使用
  • LiteIDE中配置golang编译生成无CMD窗口EXE的步骤
  • Mybatis——04
  • 【Python】基于OpenAI API实现PDF发票信息提取
  • Linux 基础入门操作 第十一章 图形界面设计
  • 【day2】数据结构刷题 栈
  • 【linux】线程概念与控制
  • 05STM32定时器-01定时器概述
  • C#测试基于OllamaSharp调用本地DeepSeek模型
  • AI基础01-文本数据采集
  • TCP/IP协议的三次握手和四次挥手
  • python爬虫Redis数据库
  • 水豚出逃40天至今未归,江苏扬州一动物园发悬赏公告
  • 巴基斯坦称成功拦截印度导弹,空军所有资产安全
  • 红场阅兵即将开始!中国人民解放军仪仗队亮相
  • 美乌基金协议:美国搞了一套可在资源富集地区复刻的商业模式
  • 国博馆刊|北朝至唐初夏州酋豪李氏家族的发展与身份记忆
  • 普雷沃斯特当选新一任天主教罗马教皇