如何计算算法的时间复杂度和空间复杂度,怎么计算算法时间复杂度

  如何计算算法的时间复杂度和空间复杂度,怎么计算算法时间复杂度

  Yyds干货库存

  目录

  分析算法时间复杂度的基本方法

  例子

  算法时间复杂度计算

  算法空间复杂度

  算法1

  算法2

  分析算法时间复杂度的基本方法1。找出出现频率最高的句子作为基础句。

  2.计算基本句的出现频率得到一个问题规模n的函数f(n)

  3.取其数量级,用符号“O”表示。

  示例分析了以下程序段的时间复杂度

  I=1;//

  while(i=n)

  I=I * 2;//关键是找出执行次数x和n之间的关系,用称为n的函数表示:

  如果循环执行一次:i=1*2=2,

  如果循环执行两次:I=2 * 2=2 ^ 2,

  如果循环执行三次:I=2 * 2 * 2=2 ^ 3,

  如果循环执行x次:I=2 * 2 *.=2 x,

  设语句执行x次,可以从循环条件i=n,2 x=n得到,所以x=log2n。

  即f(n)log2n,最大值f(n)=log2n,所以这个程序段的时间复杂度T(n)=O(log2n)。

  请注意算法时间复杂度的计算:在某些情况下,算法中基本运算的重复次数会随着问题的输入和数据集的不同而不同。

  比如顺序搜索,在数组a[i]中找到值等于E的元素并返回其位置。

  for(I=0;I n;我)

  if(a[i]==e)返回I 1;//找到,返回哪个元素?

  返回0;

  最佳情况:1次

  最坏情况:n次

  平均时间复杂度为:O(n)

  算法空间复杂度算法1 for(I=0;i i ) {

  t=a[I];

  a[I]=a[n-I-1];

  a[n-I-1]=t;

  }只创建了一个额外的测试变量,

  S(n)=O(1),原地工作。

  算法2 for(I=0;I n;我)

  b[I]=a[n-I-1];

  for(I=0;I n;我

  a[I]=b[I];产生了额外的b[i],所以S(n)=O(n)。

  原创作品来自秃弱博主,转载请联系作者获得转载授权,否则将追究法律责任。

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: