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

制作企业网站素材视频球队排名榜实时排名

制作企业网站素材视频,球队排名榜实时排名,宁波今天最新新闻头条,百度指数查询移动版这里写目录标题算法的复杂度大O的渐进表示法实例分析空间复杂度每日一题算法的复杂度 衡量一个算法的好坏,一般 是从时间和空间两个维度来衡量的, 即时间复杂度和空间复杂度。 时间复杂度主要衡量一个算法的运行快慢, 空间复杂度主要衡量一个…

在这里插入图片描述

这里写目录标题

  • 算法的复杂度
  • 大O的渐进表示法
  • 实例分析
  • 空间复杂度
  • 每日一题

算法的复杂度

衡量一个算法的好坏,一般 是从时间和空间两个维度来衡量的,
时间复杂度空间复杂度
时间复杂度主要衡量一个算法的运行快慢,
空间复杂度主要衡量一个算法运行所需要的额外空间

大O的渐进表示法

1、用常数1取代运行时间中的所有加法常数。
2、在修改后的运行次数函数中,只保留最高阶项。
3、如果最高阶项存在且不是1,则去除与这个项目相乘的常数。得到的结果就是大O阶。//一般是大O的渐进表达法是运算的最坏情况,而且最好不要通过代码中有几层循环来判断

如: 2N+10 时间复杂度为O(N)
M+N 时间复杂度为O(M+N)
(N*(N+1)/2 时间复杂度为O(N^2)

实例分析

这是一个关于二分的编码 ,把总元素看作N ,每循环一次都会少去一半的元素,共循环(logN)次这里在算法中底数为二(有些地方是lgN),所以时间复杂度为O(logN)

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),但是通过不断递归
如图所示所以时间复杂度为O(2^n)

long long Fib(size_t N)
{
if(N < 3)
return 1;
return Fib(N-1) + Fib(N-2);
}

在这里插入图片描述

空间复杂度

空间复杂度大O渐进表示法来表示,主要是临时占用存储空间大小的量度

下列代码中主要开辟三个额外的变量,用大O表达式为O(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;
}
}

如图所示 由递归思想可知每递归,递到最后时 往回归嘛,函数栈会销毁
如fibArray[2] 销毁时,fibArray[1]会使用这个被销毁的空间 所以以此类推
大O表达式为(N)

long long* Fibonacci(size_t n)
{
if(n==0)
return NULL;
long long * fibArray = (long long *)malloc((n+1) * sizeof(long long));
fibArray[0] = 0;
fibArray[1] = 1;
for (int i = 2; i <= n ; ++i)
{
fibArray[i] = fibArray[i - 1] + fibArray [i - 2];
}
return fibArray;
}

在这里插入图片描述

下列代码主要是递归思维 ,每次递归建立了一个栈帧
所以空间复杂度为(N)

long long Fac(size_t N)
{
if(N == 0)
return 1;
return Fac(N-1)*N;
}

在这里插入图片描述

每日一题

给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

void swap(int left,int right,int*nums)
{int tmp =0;while(left < right){tmp = nums[left];nums[left] = nums[right];nums[right] = tmp;left++;right--;}}void rotate(int* nums, int numsSize, int k){
if(k > numsSize)
k = k%numsSize;//如果旋转数组大于numsSize swap(numsSize-k,numsSize-1,nums);//先逆序要旋转的
swap(0,numsSize-k-1,nums);//之后逆序不旋转的
swap(0,numsSize-1,nums);//最后整个数组在逆序一遍}

在这里插入图片描述

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

相关文章:

  • 网站建设与管理的策划书做网站需要懂哪些语言
  • 商城网站建站系统源码线上海报设计网站
  • 网站备案网站宣传类的网站有哪些
  • 做模具的网站动态电子商务网站建设报告
  • 网站开发技术课程设计说明书百度官方网站首页
  • 网站注册系统源码网站开发好
  • 成都模板网站建设服务东莞百度网站排名优化
  • 网站被百度惩罚迅雷网站做爰视频
  • 网站登录 退出怎么做在国内可以做国外的网站吗
  • 泽州网站设计服务器怎么装网站吗
  • 福州网站建设专业定制烟台网站排名优化
  • 兴安盟老区建设促进会网站旅游电子商务网站开发方案
  • 网站设计制作如何评价网站之家查询域名
  • 微信端怎么建设网站做app界面设计用什么软件
  • 衡阳网站设计整合营销实施的技能包括
  • 个人网站主办者名称江西专业的企业网站建设公司
  • wordpress 回收站在哪网站搭建中单页面
  • 外贸网站翻译建设最火的深圳网站建设
  • 江苏省建设厅的官方网站安卓小程序开发入门
  • 公司营销型网站dedecms蓝色企业网站模板免费下载
  • 平顶山市网站建设公司wordpress怎么批量移动分类
  • 做花瓶的网站微信公共平台开发
  • 网站建设论文选题背景怎么看网站有没有做竞价
  • 阳信住房和城乡建设厅网站黄冈贴吧
  • 做亚马逊网站的账务处理wordpress外链图片
  • 如何向百度提交自己的网站做网站采集
  • 电子商务网站基础建设wordpress后台字体
  • 采集网站如何收录2345浏览器网页版入口中文版
  • 网站整体迁移该怎么做最新猪价
  • 免费咨询网站如何挖掘和布局网站关键词