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

河南省建设厅网站官网通州区网站快速排名方案

河南省建设厅网站官网,通州区网站快速排名方案,盐城做网站,网站页面吸引力算法在编写成可执行程序后,运行时需要消耗时间资源和空间(内存)资源,因此衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的。 时间复杂度主要衡量一个算法运行的快慢,而空间复杂度主要衡量一个算法运…

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

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

目录

一、时间复杂度的概念

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

相关文章:

  • 很多网站没排名了百度免费推广怎么做
  • 怎么样在网站上做跳转重庆seo排名优化
  • 网站推广每天必做的流程百度网址收录提交入口
  • 免费制作网站的步骤 怎样做网站成都高端网站建设哪家好
  • wordpress破解版网站优化系统
  • 餐饮业网站源码 织梦做网站用什么软件好
  • 免费创建个人商城网站百度营销登录入口
  • 各大网站推广平台课程培训
  • 计算机网站开发是什么专业产品怎么做市场推广
  • 网站给我做坏了怎么办百度一下下载
  • 网站建设公司利润怎么样邯郸seo营销
  • 营销网站的概念阿里云自助建站
  • 太原专门做网站阿里指数查询官网入口
  • 网站建站报价单百度站长号购买
  • 网站备案号 查询爱站网影院
  • 敦煌做网站的公司电话百度关键词指数
  • 涿鹿做网站wl17581网络营销的发展现状如何
  • 电商网站banner免费的网站推广软件
  • 重庆如何做聚政网站app营销策略都有哪些
  • 自己的网站怎么做商城谷歌搜索入口365
  • 营销网站的优势是什么百度邮箱注册入口
  • 网页游戏网站打不开东莞疫情最新情况
  • 用jsp做的购物网站东莞网站建设推广品众
  • 做电影网站要不要收费产品设计公司
  • 手机网站排名优化软件新媒体运营培训班
  • 团建网站建设国际重大新闻事件10条
  • 崇左北京网站建设如何提高网站排名的方法
  • 怎么建设色情网站成都网站seo推广
  • 网页模版图片哈尔滨优化网站公司
  • 机械加工网免费注册seo编辑的工作内容