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

河南省建设厅网站官网永久免费跨境浏览app

河南省建设厅网站官网,永久免费跨境浏览app,photoshop做网站设计,武汉网站制作定制算法在编写成可执行程序后,运行时需要消耗时间资源和空间(内存)资源,因此衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的。 时间复杂度主要衡量一个算法运行的快慢,而空间复杂度主要衡量一个算法运…

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

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

目录

一、时间复杂度的概念

二、大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.khdw.cn/news/40257.html

相关文章:

  • 做响应式网站的微博号上海小红书seo
  • 设计网页价格网站seo外链建设
  • 带产品多用户商城seo是什么
  • 给公司做网站要花多钱站长工具无忧
  • 企业网站定制收费标准百度教育官网
  • 威海建设集团网站推广方案是什么
  • 网站一起做网店怎么把平台推广出去
  • 网站维护要多久时间济南seo排名优化推广
  • 如何做网站开发seo优化网站网页教学
  • 自己怎么建设一个网站百度平台电话多少
  • wordpress按条件搜索功能搜索引擎优化方法总结
  • 惠州建站免费模板2345网址大全设主页
  • 宁波做网站首荐荣盛网络中国局势最新消息今天
  • 婚纱摄影网站html模板关键词看片
  • 百度 网站质量网站链接查询
  • 威海相亲网站宁波seo网站推广
  • 长沙网站制作收费明细表湖北疫情最新情况
  • 做文案选图片素材的网站家庭优化大师下载
  • 做网站如何被收录怎样推广自己的网站
  • 网站的做用品牌软文案例
  • 桂林市政府网站官网品牌seo推广
  • 域名托管seo求职信息
  • 驾校网站建设方案题婚品牌广告图片
  • 为什么做网站要有自己的服务器如何优化网站推广
  • 帝国 只做网站地图深圳优化服务
  • 做网站制作的公司宁夏百度推广代理商
  • 江苏建设网站首页自己搜20条优化措施
  • erp仓库管理系统福州seo扣费
  • 深圳价格实惠的网站建设公司天津seo
  • php公司网站系统什么网站做推广比较好