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

网站建设后期维护流程wordpress 运行好慢

网站建设后期维护流程,wordpress 运行好慢,免费空间申请哪个好,php技术的网站开发目录 1.线性表2.顺序表 - SeqList3.实现4.顺序表缺点 1.线性表 线性表(linear list)是n个具有相同特性的数据元素的有限序列线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串…线性表在逻辑上是线性结构&#xff0…

目录

  • 1.线性表
  • 2.顺序表 - SeqList
  • 3.实现
  • 4.顺序表缺点


1.线性表

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

2.顺序表 - SeqList

  • 概念及结构

    • 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改 (此数组必须从第一个位置开始,连续存储)

    请添加图片描述

  • 动态顺序表 – 使用动态开辟的数组存储


3.实现

  • 接口
typedef int SLDataType;//类型重命名,方便以后维护替换别的类型typedef struct SeqList
{SLDataType* arr;//指向动态数组指针int size;//有效数据个数int capacity;//容量 - 空间大小
}SL;//顺序表初始化
void SLInit(SL* ps);
//销毁顺序表
void SLDestroy(SL* ps);
//打印顺序表
void SLPrint(SL* ps);//检测增容
void SLCheckCapacity();//增删查改
//尾插/尾删 - O(1)
void SLPushBack(SL* ps, SLDataType x);
void SLPopBack(SL* ps);//头插/头删 - O(N)
void SLPushFront(SL* ps, SLDataType x);
void SLPopFront(SL* ps);//从任意位置插入/删除
void SLInsert(SL* ps, int pos, SLDataType x);
void SLErase(SL* ps, int pos);//查找和修改
int SLSearch(SL* ps, SLDataType x);
void SLModify(SL* ps, int pos, SLDataType x);
  • 接口实现
void SLInit(SL* ps)
{assert(ps);ps->arr = NULL;ps->size = 0;ps->capacity = 0;
}void SLDestroy(SL* ps)
{assert(ps);if (ps->arr){free(ps->arr);ps->arr = NULL;ps->capacity = 0;ps->size = 0;}
}void SLPrint(SL* ps)
{assert(ps);int i = 0;for (i = 0; i < ps->size; i++){printf("%d ", ps->arr[i]);}printf("\n");
}void SLCheckCapacity(SL* ps)
{assert(ps);//检查容量空间,满了扩容if (ps->size == ps->capacity){ps->capacity = ps->capacity == 0 ? 4 : ps->capacity * 2; //最大容量扩容SLDataType* tmp = realloc(ps->arr, ps->capacity * sizeof(SLDataType));if (NULL == tmp){perror("realloc:");exit(1);}ps->arr = tmp;}
}void SLPushBack(SL* ps, SLDataType x)
{assert(ps);SLCheckCapacity(ps);ps->arr[ps->size] = x;ps->size++;//SLInsert(ps, ps->size, x); //以上代码可以用这个封装替换了
}void SLPopBack(SL* ps)
{assert(ps);//暴力检查 - 适用于调试阶段assert(ps->size > 0);//温柔检查 - 适用于和用户交互使用//if (0 == ps->size)//{//	printf("SeqList is empty\n");//	return;//}ps->size--;SLErase(ps, ps->size - 1); //以上代码可以用这个封装替换了
}void SLPushFront(SL* ps, SLDataType x)
{assert(ps);SLCheckCapacity(ps);//挪动数据int end = ps->size - 1;while (end >= 0){ps->arr[end + 1] = ps->arr[end];end--;}ps->arr[0] = x;ps->size++;//SLInsert(ps, 0, x); //以上代码可以用这个封装替换了
}void SLPopFront(SL* ps)
{int begin = 1;while (begin < ps->size){ps->arr[begin - 1] = ps->arr[begin];begin++;}ps->size--;//SLErase(ps, 0); //以上代码可以用这个封装替换了
}void SLInsert(SL* ps, int pos, SLDataType x)
{assert(ps);assert(pos >= 0 && pos <= ps->size); //检验位置合法性SLCheckCapacity(ps);//挪动数据int end = ps->size - 1;while (end >= pos){ps->arr[end + 1] = ps->arr[end];end--;}ps->arr[pos] = x;ps->size++;
}void SLErase(SL* ps, int pos)
{assert(ps);assert(pos >= 0 && pos < ps->size);//挪动数据int begin = pos;while (begin < ps->size - 1){//后面的数据往前搬ps->arr[begin] = ps->arr[begin + 1];begin++;}ps->size--;
}int SLSearch(SL* ps, SLDataType x)
{assert(ps);int i = 0;for (i = 0; i < ps->size; i++){if (ps->arr[i] == x){return i;}}return -1;
}void SLModify(SL* ps, int pos, SLDataType x)
{assert(ps);assert(pos >= 0 && pos < ps->size);ps->arr[pos] = x;
}

4.顺序表缺点

  • 空间不够,需要扩容。
    • 扩容有一定性能损耗
    • 一般扩容两倍,存在一些空间浪费
  • 头部或者中间位置插入删除效率低下 – 挪动数据
  • 改善方案 – 链表 – 对顺序表缺陷的优化
    • 按需申请释放空间
    • 头部或者中间插入删除,不需要挪动数据
http://www.yayakq.cn/news/389992/

相关文章:

  • 在线网页代理浏览免费通辽做网站0475seo
  • 如何查看网站流量wordpress 点评插件
  • 如何做网站条幅闪图承德手机网站建设
  • 中建招聘网站大庆市城乡建设局网站首页
  • 网站建设质量管理定义网站的制作与调试
  • 珠海做网站优化网站开发人员需要什么技能
  • wordpress 直播 视频宁波网站优化公司电话
  • 网站怎么做运营推广广东省建设工程执业中心网站
  • 太原推广型网站建设轻松学做网站
  • 乐山住房和城乡建设厅网站服装网站推广策划书
  • 做网站用属于前端网站开发有哪些架构
  • 石家庄网站建设培训学校佛山网站建设锐艺传播
  • 奥远网站建设流程WordPress建站步骤
  • 怎么在网站做支付端口对接自助式网站制作
  • 网站怎样制作吸引人建设工业
  • 做电商网站都需要学什么网站建设服务专业
  • 做网站招标电子商务网站html模板
  • 网站建设网页制作软件深圳自助网站建设
  • 交换机可以做网站跳转吗在线制作电子公章生成器
  • 单仁牛商河南网站建设优化技术
  • 数据库性质的网站怎么做营销网站建设解决方案
  • dede做手机网站wordpress文章存储位置
  • 度假区网站建设方案网络架构图描述
  • 石家庄网站设计培训班wordpress查询文章分类
  • 阿里巴巴网站建设分析泰州网站建设方案
  • wordpress技术分析沈阳网站建设优化企业
  • 凡科建站网站万网影
  • 家居网站建设全网营销网络管理系统中管理对象
  • 网站的建设意义自问自答网站怎么做
  • 陕西建设机械股份有限公司网站wordpress微博评论箱