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

wordpress 中国加速优化设计数学

wordpress 中国加速,优化设计数学,图片摄影网站,可以做视频推广的网站有哪些顺序表 1. 线性表2. 顺序表2.1 静态顺序表2.2 动态顺序表2.2.1 动态数据表初始化和销毁2.2.2 动态数据表的尾插尾删2.2.3 动态数据表的头插头删2.2.4 动态数据表的中间部分插入删除2.2.5 动态数据表的查询数据位置 3. 总结 1. 线性表 线性表(linear list&#xff0…

顺序表

  • 1. 线性表
  • 2. 顺序表
    • 2.1 静态顺序表
    • 2.2 动态顺序表
      • 2.2.1 动态数据表初始化和销毁
      • 2.2.2 动态数据表的尾插尾删
      • 2.2.3 动态数据表的头插头删
      • 2.2.4 动态数据表的中间部分插入删除
      • 2.2.5 动态数据表的查询数据位置
  • 3. 总结

1. 线性表

线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串…
线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。
在这里插入图片描述

2. 顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。顺序表严格来说就是一个数组!
要求:数据连续存储!

顺序表一般分为静态顺序表动态顺序表

2.1 静态顺序表

静态顺序表:使用定长数组存储元素。
在这里插入图片描述

由于使用时无法增加内部容量,所以静态顺序表只适用于确定知道需要存多少数据的场景

静态顺序表的定长数组导致N定大了,空间开多了浪费,开少了不够用。所以现实中基本都是使用动态顺序表,根据需要动态的分配空间大小。

2.2 动态顺序表

动态顺序表:使用动态开辟的数组存储。

typedef int SLDataType;
// 顺序表的动态存储
typedef struct SeqList
{SLDataType* array;  // 指向动态开辟的数组size_t size ;       // 有效数据个数size_t capicity ;   // 容量空间的大小
}SeqList;

在这里插入图片描述
作为一个可以进行修改的顺序表,所以动态顺序表必须要满足以下的条件:

1.顺序表 初始化
2.顺序表 增加数据
3.顺序表 删除数据
4.顺序表 查找数据
5.顺序表 修改数据
6.顺序表 插入数据
7.顺序表 销毁

2.2.1 动态数据表初始化和销毁

//初始化
void SeqListInit(SeqList* ps)
{ps->a = NULL;ps->size = 0;ps->capacity = 0;
}
//销毁
void SeqListDestroy(SeqList* ps)
{if(ps->a != NULL){free(ps->a);ps->a =NULL;ps->size = ps->capacity = 0;}
}

2.2.2 动态数据表的尾插尾删

//顺序表尾插
void SeqListPushBack(SeqList* ps, SLDataType x)
{//检查容量,如果不够扩容if(ps->size == ps->capacity){int newCapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;SLDataType* tmp  = (SLDataType*)realloc(ps->a, newCapacity * sizeof(SLDataType));//判断扩容是否成功if(tmp == NULL){perror("realloc fail!");exit(-1);}ps -> a = tmp;ps->capacity = newCapacity;}//将数据插入到顺序表中ps->a[size] = x;ps->size++;
}
//顺序表尾删
void SeqListPopBack(SeqList* ps)
{//暴力检查assert(ps->size > 0);ps->size--;
}

2.2.3 动态数据表的头插头删

// 检查空间,如果满了,进行增容
void CheckCapacity(SeqList* ps)
{if(ps->size == ps->capacity){int newCapacity = ps->capacity == 0 ? 4 : ps->capacity*2;SLDataType* tmp = (SLDataType*)realloc(ps->a, newCapacity * sizeof(SLDataType));if(tmp == NULL){perror("realloc fail!");exit(-1);}ps->a = tmp;ps->capacity = newCapacity;}
}// 顺序表头插
void SeqListPushFront(SeqList* ps, SLDataType x)
{	assert(ps);//检查顺序表是否为空,为空直接报错CheakCapacity(ps);//检查是否需要扩容  //由于多个地方都需要扩容,为了避免重复代码,选择复用代码//将前一个数据放到后面的空格中int end = ps->size - 1;	while(end >= 0){ps->a[end + 1] = ps->a[end]; --end;}ps->a[0] = x;ps->size++;
}
// 顺序表头删
void SeqListPopFront(SeqList* ps)
{assert(ps);assert(ps->size > 0);//直接移动数据进行覆盖int begin = 0;while(begin < ps-> size - 1){ps->a[begin] = ps->a[begin+1];++begin;}ps->size--;
}

写到这里,仔细思考的话,会发现头插的时间复杂度是O(N),尾插的时间复杂度是O(1);因此顺序表的数据插入一般会使用尾插。

2.2.4 动态数据表的中间部分插入删除

// 顺序表在pos位置插入x
void SeqListInsert(SeqList* ps, size_t pos, SLDataType x)
{assert(ps);assert(pos >= 0 );//相等就是头插尾插assert(pos <= ps->size);//检查扩容CheckCapacity(ps);//移动int end = ps->size -1;while(end >= pos)//pos位置的数据也要移动{ps->a[end + 1] = ps->a[end]; end--;}ps->a[pos] = x;ps->size++;
}
// 顺序表删除pos位置的值
void SeqListErase(SeqList* ps, size_t pos)
{assert(ps);assert(pos >= 0);assert(pos < ps->size);int begin = pos+1;while(begin < ps->size){ps->a[begin] = pos->a[begin - 1];begin++;}ps->size--;
}

2.2.5 动态数据表的查询数据位置

// 顺序表查找
int SeqListFind(SeqList* ps, SLDataType x)
{assert(ps);for(int i=0;i < ps->size; ++i){if(ps->a[i] == x){return i;}}return -1;
}

3. 总结

  1. 首先,顺序表是连续的存储空间,不能断开。静态顺序表用的很少,几乎都是动态顺序表。默认说的顺序表是动态顺序表。
  2. 其次,顺序表提供增删查改,但是相对来说顺序表使用尾插最好,时间复杂度最低。
  3. 第三,顺序表一旦提供在中间的增删后,头插尾插和头删尾删都可以用中间的增删来进行复用。
http://www.hkea.cn/news/611697/

相关文章:

  • 网站根目录文件名游戏推广员是做什么的
  • 个体工商户怎么做网站西安网站seo技术
  • 报名网站制作2345网址导航官网下载安装
  • 图书购物网站开发总结百度发广告需要多少钱
  • 做网站 业务流程图站长统计性宝app
  • 长沙做网站大概多少钱万网域名注册教程
  • 成都网站建设网站产品推广计划书怎么写
  • 深圳个人网站建设大连网络推广公司哪家好
  • 建设工程教育appseo技术培训中心
  • 家教中介怎么利用网站来做的免费广告推广
  • wordpress仿制建设seo是什么平台
  • 商城网站建设分为几块seo臻系统
  • 网络营销对于个人而言有什么作用seo文章
  • 做书籍封皮的网站今日中国新闻
  • 东莞建设网站电工培训技术学校
  • 深圳聘请做网站人员成都排名seo公司
  • 网站备案之后东莞网站关键词优化公司
  • 多种专业网站建设潍坊网站排名提升
  • 网站投稿系统怎么做网站制作流程是什么
  • 交警网站建设整改百度推广怎么推广
  • 重庆网站建设哪里比较好呢网站下载
  • 网站运行速度慢的原因看b站二十四小时直播间
  • 电商网站开发服务全网营销骗局揭秘
  • 个人网站怎么做互联网营销师培训课程免费
  • 微信网站建设价格网站开发报价方案
  • wordpress utc时间慢8小时大连seo关键词排名
  • 中国建设承包商网站创建软件平台该怎么做
  • 中小企业网站建设费用海外推广服务
  • 企业名称的英文做网站名seo是怎么优化推广的
  • 手机在线建站西安seo服务公司