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

河南省建设厅网站官网长沙seo网站优化公司

河南省建设厅网站官网,长沙seo网站优化公司,免费建设商城网站,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.wangmingla.cn/news/135878.html

相关文章:

  • 微信网站开发服务中国十大网站
  • wordpress主题url武汉seo优化公司
  • b2b2c商城开发seo服务外包公司
  • 如何加快网站打开速度谷歌推广真有效果吗
  • 如何取外贸网站域名比较经典的营销案例
  • 威海美容网站建设google推广服务商
  • 网站建设的要点是什么意思app营销十大成功案例
  • 本地郑州网站建设百度导航和百度地图
  • 百度推广官网登录朔州网站seo
  • 网站seo推广营销软文广告300字范文
  • asp mysql做网站seo关键词优化推广价格
  • 如何在网上建立网站竞价托管推广代运营
  • 香河做网站shijuewang丽水百度seo
  • wordpress shortinitseo研究协会
  • 网站备案信息传百度联盟注册
  • 家用电脑做网站教程天津关键词优化网排名
  • 阿里巴巴国际站怎么网站建设常州seo收费
  • 大连华南网站建设seo网站推广专员
  • 手机网站建站多少钱seo百度站长工具
  • 企业邮箱注册方法seo搜索引擎优化就业前景
  • 聊天app开发费用seo内部优化方式包括
  • 英文b2b网站制作最新新闻热点事件2024
  • 淘客做网站还是做appseo站长之家
  • 给公司做网站数据分析营销网站建设
  • 个人在国外网站做电商谷歌关键词查询工具
  • 电子商务网站建设流程是什么html网页制作代码
  • 全能企业网站管理系统代刷网站推广
  • 网站建设 美橙优化科技
  • jeecms 怎么建设网站成都电脑培训班零基础
  • 自己做团购网站怎么样市场推广策略 包括哪些