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

网站图标目录哈尔滨网站建设的公司

网站图标目录,哈尔滨网站建设的公司,做网站公司起什么名字,wordpress 的分类目录这里写目录标题算法的复杂度大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/504921/

相关文章:

  • 泗水县城乡建设局网站荆州网站建设费用
  • 做网站是用myecliWordPress搭建手机网站
  • 正规接单网站制作网站公
  • 手机网站免费制作平台有哪些wordpress主题设置选项
  • 网站建设面试试题软件技术是干什么的
  • 卖域名的网站哪个好做水果网站首页的图片素材
  • 嘉兴建设中学网站网站建设如何为企业电商化转型赋能
  • 视频网站后台管理系统硬件开发是什么意思
  • 网站建设专业网站设计公司物格网企业网站设计与建设
  • 海宁做网站常宁市城乡和住房建设网站
  • 视频播放网站建设房地产网站建设内容
  • 让移动网站动漫设计专业的学校
  • 在线教学的网站开发方案wordpress积分查看
  • 教育网站制作设计那里网站建设好
  • 网站开发应用开发代做施组 方案的网站
  • 郑州模板建站多少钱郑州百度推广开户
  • 大数据营销网站北京南站到北京站坐地铁几号线
  • 19年做网站电子贺卡制作
  • 一个公司可以做两个网站推广吗提供给他人做视频解析的网站源码
  • 微博如何做外链到时自己网站网络品牌塑造
  • 让别人做网站要注意什么6网站建设工作会议召开
  • 北京互联网公司建网站朋友圈网站广告怎么做
  • 营销型网站建设明细报价表wordpress 监测插件
  • 怎么让百度搜到自己的网站打开网站速度
  • 开家网站建设培训学校网站怎么做要多少钱
  • 电商网站前端模板2022国际国内重大新闻
  • 程序员会搭建非法网站吗玉林城乡住房建设厅网站
  • 网站如何设计搜索框海口模板网站建站
  • 交河做网站个人备案网站可以做新闻站吗
  • 购物网站开发案例下载苏州市工业园区规划建设局网站