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

福州做网站公司排名营销策划模板

福州做网站公司排名,营销策划模板,手机app下载安装到手机,wordpress 自定义widget最近更新的少,主要是因为参加了ACM竞赛空间复杂度空间复杂度也是一个数学表达式,是对一个算法在运行过程中临时占用存储空间大小的量度 。空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量…

最近更新的少,主要是因为参加了ACM竞赛

空间复杂度

  1. 空间复杂度也是一个数学表达式,是对一个算法在运行过程中临时占用存储空间大小的量度

  1. 空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数

  1. 空间复杂度计算规则基本跟实践复杂度类似,也使用大O渐进表示法。

  1. 注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显式申请的额外空间来确定。也就是说数据源的空间不能计算在内。

  1. 时间一去不复返,也就是说不能够重复利用;但是空间用了之后就能够归还,因此空间可以重复利用,比如下面这个例子:

上面这个的空间复杂度就是O(N),因为我要运行这个算法在这个过程当中,我需要去额外开辟空间,这是跟我的数据源无关的,我额外开辟的空间。

当前函数在调用的时候,为开辟对应的函数栈帧,如果函数里面又会调用函数,那么当前函数的函数栈帧并不会被销毁,上面这个的空间复杂度也是O(N)

那么重头戏来了,这个的空间复杂度是多少?首先的话必须要了解到底函数的调用顺序是怎么样的?就看我的这张图:

这种函数执行的顺序有点类似于深度优先搜索,到底了之后那个函数执行结束之后就会销毁函数栈帧,接下来再去调用函数,对于总的空间来说已经不会再增加,因此空间复杂度就是O(N)。

  1. 虽然说空间复杂度统计的是变量的个数,如果说函数里面并没有创建变量,那么我们认为在这个函数栈帧里面的空间大小为一个常数,也就是O(1)。

  1. 对于数组而言,有几个元素就表示所谓的变量个数。

线性表

  1. 数据结构的作用:在内存当中存储与管理数据。

  1. 线性表是n个具有相同特性的数据元素的有限序列,线性表是一种常用的数据结构。比较常见的线性表有:顺序表,链表,栈,队列,字符串.......。我们说线性表在逻辑上是线性结构,也就是说好比一条连续的直线。但是在物理结构上并不一定是连续的。在物理上存储时,通常以数组和链式结构的形式存储

顺序表(SeqList)

  1. 顺序表就是写一个结构体,然后通过这个结构对数组进行管理,存储数据就是用数组存储

1.创建一个顺序表

//创建一个结构体
typedef int SLDataType;
typedef struct SeqList
{SLDataType* p;size_t size;size_t capacity;
}SeqList;

2.顺序表的初始化

#define INIT_CAPACITY 5
void SeqListInit(SeqList* ps)
{ps->p = (SeqList*)malloc(sizeof(SLDataType) * INIT_CAPACITY);if (ps->p = NULL){perror("SeqListInit::Malloc:");return;}ps->size = 0;ps->capacity = INIT_CAPACITY;
}

3.顺序表使用结束后的销毁

void SeqListDestroy(SeqList* ps)
{free(ps->p);ps->p = NULL;ps->capacity = 0;ps->size = 0;
}

4.打印顺序表

void SeqlistPrint(SeqList* ps)
{for (int i = 0; i < ps->size; i++){printf("%d ", *(ps->p + i));}printf("\n");
}

5.顺序表的尾插

void SeqListPushBack(SeqList* ps, SLDataType x)
{if (ps->size == ps->capacity){SLDataType* pp = (SLDataType*)realloc(ps->p, sizeof(SLDataType) * ps->capacity * 2);if (pp == NULL){perror("SeqListPushBack::Realloc");return;}ps->p = pp;}*(ps->p + ps->size) = x;ps->capacity *= 2;ps->size++;
}

6.顺序表的尾删

void SeqListPopBack(SeqList* ps)
{assert(ps->size > 0);ps->size--;
}

未完,待续........

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

相关文章:

  • 格泰网站建设网站建设设计公司哪家好
  • 申请建设网站的报告广东seo网络培训
  • 帝国网站管理 上一条 下一条 链接 信息id 信息发布时间瑞安市住房和城乡建设局网站
  • 儿童教育网站模板wordpress修改页面
  • 58网站模板企业网站建设策划书标准版
  • 株洲seo网站推广网页制作与网站建设答案
  • 怎样监测熊掌号绑定成功网站企业网站建设杭州公司
  • 网站建设先进个人典型材料数字营销平台有哪些
  • 松滋网站定制建站系统的应用场景
  • 佛山市做网站的公司上海平台网站制作公司
  • 物流网站怎么开甘肃省建设厅质量投诉网站
  • 企业网站建设457网页模板的制作步骤
  • 怎么用ftp备份网站php网站开发有什么优点
  • 新建南昌网站建设公司怎么在网站上放广告
  • 鞍山网站建设设计素材网站照片
  • 在那里建立公司网站wordpress vs
  • iis默认网站 没有属性如何实现一个响应式网页
  • 公司网站制作费算是无形资产吗wordpress固定
  • 简述网站设计的开发流程软件制作公司
  • 如何创建属于自己的网站怎么设计海报图片
  • h5响应式网站建设程序开发需要学什么
  • 用视频做网站背景提供网站制作公司哪家专业
  • 青海省安建设管理部门网站单品网站模板
  • 如何做网站主赚钱网站建设排名公司
  • 如何网站全部结构化妆培训学校网站建设
  • 南宁软件优化网站上海做网站联系电话
  • e建网站长春网站优化哪家好
  • 旅游网站的市场需求怎么做介绍湘潭网站建设 磐石网络在哪
  • 多伦多网站建设多少钱云南 网站建设网站
  • 做义工的同城网站wordpress 后台无法打开