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

网站路径网页程序开发学什么语言

网站路径,网页程序开发学什么语言,外贸建站,wordpress 安装新主题算法在编写成可执行程序后,运行时需要消耗时间资源和空间(内存)资源,因此衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的。 时间复杂度主要衡量一个算法运行的快慢,而空间复杂度主要衡量一个算法运…

        算法在编写成可执行程序后,运行时需要消耗时间资源和空间(内存)资源,因此衡量一个算法的好坏,一般是从时间空间两个维度来衡量的。

        时间复杂度主要衡量一个算法运行的快慢,而空间复杂度主要衡量一个算法运行所需要的额外空间,今天我们主要来讲讲时间复杂度。

目录

一、时间复杂度的概念

二、大O的渐进表示法

三、常见的时间复杂度计算


一、时间复杂度的概念

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

二、大O的渐进表示法

实际计算时间复杂度时,我们并不需要计算精确的执行次数,而只需要大概执行次数,那么这里我们使用大O的渐进表示法。

大O符号:是用于描述函数渐进行为的数学符号。

推导大O阶的方法:

1、用常数1取代运行时间中所有的加法常数。

2、在修改后的运行次数函数中,只保留最高阶项。

3、如果最高阶项存在且不是1,则去除与这个项相乘的常数,得到的结果就是大O阶。

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

最坏情况:

任意输入规模的最大运行次数(上线)

平均情况

任意输入规模的期望运行次数

最好情况:

任意输入规模的最小运行次数

例如,在一个长度为N的数组中搜索一个数据x

最好情况:一次找到

平均情况:N/2次找到

最坏情况:N次找到

在实际中一般情况关注的是算法的最坏运行情况,所以数组中搜索数据时间复杂度为O(N)

三、常见的时间复杂度计算

实例1:

void BubbleSort(int *a,int n)
{assert(a);for(size_t end=n;end>0;--end){int exchange = 0;for(size_t i=1;i<end;++i){if(a[i-1]>a[i]){Swap(&a[i-1],&a[i]);exchange=1;}}if(exchange=0)break;}
}

该例子为冒泡排序,最好的情况为,比较完一轮(N-1次)后,发现就顺序的,所以最好是N次。

最坏是(N*(N+1))/2次,通过推导大O阶方法+时间复杂度一般看最坏,时间复杂度为O(N^2).

实例2:

//二分查找
int BinarySearch(int* a, int n, int x)
{assert(a);int begin = 0;int end = n - 1;while (begin <= end){int mid = begin + ((end - begin) >> 1);if (a[mid] < x){begin = mid + 1;}else if(a[mid]>x){end = mid - 1;}else{return mid;}}return -1;
}

二分查找:

最好情况:中间那个数就是要找的O(1)

最坏情况:一直除2,,到只剩一个值时,要么找到了,要么找不到。

假设N是数组个数,x是最坏查找次数,N/2/2/2……/2=1

2^x=N,x=logN(logN在算法分析中表示以2为底数,N为对数,有些地方也写成lg N)

实例3:

//计算斐波那契数列的时间复杂度
long long Fib(size_t N)
{if (N < 3)return 1;return Fib(N - 1) + Fib(N - 2);
}

 运用等比数列求和公式可知,执行次数为2^N的数量级

所以时间复杂度应为O(2^N)

实例4:

//计算阶乘递归Fac的时间复杂度
long long Fac(size_t N)
{if (0 == N)return 1;return Fac(N - 1) * N;
}

时间复杂度为O(N)

http://www.yayakq.cn/news/348831/

相关文章:

  • 商务网站设计实训报告境外注册网站
  • 石家庄网站建设成功案例微信开放平台开发者
  • 贵阳网络公司网站建设sem广告投放是做什么的
  • 网站建设公司豆瓣深圳网络公司推广公司
  • 网站要实名认证成都住建局官网报名被挤爆黑幕
  • 做网站用什么开源苍南网站开发
  • 成都网站建设空间重庆网站建设 制作 设计 优惠价
  • 自己如何免费制作一个网站图书馆网站开发策划书
  • 网站的开发建设要做什么免费的外网服务器
  • 网站开发语言分析百度指数查询
  • 高邮市建设局网站photoshop在线修图
  • 公司网站开发款记什么科目佛山外贸网站建设渠道
  • 三门峡 网站开发企业宣传片的制作流程
  • 网站建设规划书百度文库团购网站前景
  • 建立网站需要多少钱萍畜湖南岚鸿首选网站调研怎样做
  • 大型网站建设优化企业网站建设图片logo
  • 专业网站定制 北京sae wordpress 媒体库
  • 部队网站建设报告公司做网站需要注意些什么问题
  • 企业名录搜索软件 2022广州百度推广排名优化
  • 赣州市铁路建设办公室网站蜜蜂vp加速器七天试用
  • 网站空间可以自己买吗网站技术培训班有哪些种类
  • 网站部署到终端机怎么做wordpress 工具栏图标
  • 营销型网站建设平台淄博铭锐 网站建设
  • 模板网站多钱韩国做hh网站
  • mysql做网站互联网营销外包公司
  • 重庆网站房地产网站建设sz886
  • 本地搭建多个网站什么叫seo优化
  • 全屏企业网站欣赏国外的网站用不用备案
  • 定制一个企业网站多少钱浙江网上注册公司流程
  • 惠州网站建设效果中国交通建设集团第四工程局网站