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

网站平台建设规划wordpress tw

网站平台建设规划,wordpress tw,手机百度账号登录入口,wordpress手机版论坛顺序表是线性表的一种。 线性表是n个具有相同特性的数据元素的有限序列。 逻辑上#xff0c;它们是线性结构#xff0c;是一条连续的直线#xff1b;但是在物理上#xff0c;它们通常以数组和链式结构存储。 常见的线性表有顺序表、栈、队列、字符串等。 顺序表是用一段…顺序表是线性表的一种。 线性表是n个具有相同特性的数据元素的有限序列。 逻辑上它们是线性结构是一条连续的直线但是在物理上它们通常以数组和链式结构存储。 常见的线性表有顺序表、栈、队列、字符串等。 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构一般情况下采用数组存储在数组上完成数据的增删查改。 但是要注意动态顺序表的物理地址不一定连续它的物理地址是否连续困扰了我好长时间直到读到了这篇文章http://www.manongjc.com/detail/56-gahnkhbaweoyxwy.html 顺序表一般可以分为 1. 静态顺序表使用定长数组存储。 2. 动态顺序表使用动态开辟的数组存储。 以下是swarthmore对动态顺序表的解释 Dynamically allocated arrays are allocated on the heap at run time. The heap space can be assigned to global or local pointer variables that store the address of the allocated heap space (point to the first bucket). To dynamically allocate space, use calls to malloc passing in the total number of bytes to allocate (always use the sizeof to get the size of a specific type). A single call to malloc allocates a contiguous chunk of heap space of the passed size. 原文链接 https://www.cs.swarthmore.edu/~newhall/unixhelp/C_arrays.html#:~:textDynamically%20allocated%20arrays%20are%20allocated,point%20to%20the%20first%20bucket). 动态顺序表的基本形态 typedef struct SeqList {SLDataType* a;int size; // 有效数据个数int capacity; // 空间容量 }SL; 下面是动态顺序表的接口实现 一、初始化 typedef int SLDataType; #define INIT_CAPACITY 4 void SLInit(SL* ps) {ps-a (SLDataType*)malloc(sizeof(SLDataType)* INIT_CAPACITY);if (ps-a NULL){perror(malloc fail);return;}ps-size 0;ps-capacity INIT_CAPACITY; } 使用malloc函数向系统申请一定数量的空间。 如果没有申请成功则a为NULL。 如果申请成功了那a就不是NULL了size将会被初始化为0。 由于已经成功申请了sizeof(SLDataType)* INIT_CAPACITY个空间那么capacity的值就为INIT_CAPACITY。 二、检查和扩容 void SLCheckCapacity(SL* ps) {assert(ps);if (ps-size ps-capacity){SLDataType* tmp (SLDataType*)realloc(ps-a, sizeof(SLDataType) * ps-capacity * 2);if (tmp NULL){perror(realloc fail);return;}ps-a tmp;ps-capacity * 2;} } 当数据个数和空间容量相等时进行扩容。 这时要用到realloc函数了即从ps-a的位置开始向后申请sizeof(SLDataType)*ps-capacity*2个空间。 对的没错在这里申请的空间是原来空间的1倍。当然可以申请别的大小的空间。 然后让a指向新开辟的空间的地址将它们连接起来。 容量大小也相对应地乘2。 三、插入元素 typedef int SLDataType; #define INIT_CAPACITY 4 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-a[end 1] ps-a[end];--end;}ps-a[pos] x;ps-size; } 在插入元素之前要用断言看看要插入的位置有没有在有效数据个数之内。 如果等于size就相当于尾插如果等于0就相当于头插。 所以在这里0和size是有必要的。 然后不断循环将要插入的位置原来的元素以及它后边的元素向后移动直至endpos。 四、删除元素 typedef int SLDataType; #define INIT_CAPACITY 4 void SLErase(SL* ps, int pos) {assert(ps);assert(pos 0 pos ps-size);int begin pos 1;while (begin ps-size){ps-a[begin - 1] ps-a[begin];begin;}ps-size--; } 删除元素本质上是将要删除的元素用循环从后向前覆盖 最后size自减1。 五、头插 typedef int SLDataType; #define INIT_CAPACITY 4 void SLPushFront(SL* ps, SLDataType x) {SLInsert(ps, 0, x); } 在插入元素的基础上实现头插。 六、头删 typedef int SLDataType; #define INIT_CAPACITY 4 void SLPopFront(SL* ps) {SLErase(ps, 0); } 在删除元素的基础上实现头删。  七、尾插 typedef int SLDataType; #define INIT_CAPACITY 4 void SLPushBack(SL* ps, SLDataType x) {SLInsert(ps, ps-size, x); } 在插入元素的基础上实现尾插。  八、尾删 typedef int SLDataType; #define INIT_CAPACITY 4 void SLPopBack(SL* ps) {SLErase(ps, ps-size-1); } 在删除元素的基础上实现尾删。  九、查找元素 int SLFind(SL* ps, SLDataType x) {assert(ps);for(int i 0; i ps-size; i){if (ps-a[i] x){return i;}}return -1; } 即遍历数组找到后返回数组下标。 十、打印数组 typedef int SLDataType; #define INIT_CAPACITY 4 void SLPrint(SL* ps) {assert(ps);for (int i 0; i ps-size; i){printf(%d , ps-a[i]);}printf(\n); } 遍历打印输出即可。 十一、销毁 typedef int SLDataType; #define INIT_CAPACITY 4 void SLDestroy(SL* ps) {assert(ps);free(ps-a);ps-a NULL;ps-capacity ps-size 0; }
http://www.hkea.cn/news/14355954/

相关文章:

  • 百度建网站要多少钱工业设计灵感网站
  • 小程序是什么沧州seo排名
  • 百度网站建设目标自己做网站卖货多少钱
  • 手机网站开发介绍室内设计效果图平面图
  • 网站编程培训机构排名前十常见的cms系统
  • php按步骤做网站互联网公司的最新排名
  • 网站数据统计工具怎样做论坛网站
  • 上饶专业的企业网站开发公司番禺网站建设三杰科技
  • 公司网站能否申请国外免费空间网站与域名的关系
  • 做企业网站需要买什么优化模型的推广
  • 重庆哪里做网站网络营销相关理论
  • 四字母net做网站怎么样网站备案要幕布
  • 企业网站功能怎么设计wordpress4.6.9
  • 直播做ppt的网站有哪些沈阳红方城网站建设
  • 深圳企业建网站公司网站建设个人工作室
  • 用织梦做领券网站怎么用织梦做网站后台
  • 网站重定向怎么做万江做网站的公司
  • 企业建站用什么软件厦门海沧区建设局网站
  • 上饶建站公司静态网站建设平台
  • 网站建设公司哪家比较好建设一个网站需要什么技术
  • 个人网站怎么推广专业网站模仿
  • 旅游网站建设经费预算网络及it维护外包
  • 东莞网站推广教程扬中经济
  • 湖北德升建站品牌营销案例分析
  • 有关网站开发的文章网站的国际化 怎么做
  • 幼儿网站模板温州专业手机网站制作哪家便宜
  • 深圳 网站建设设计九口袋网站建设
  • 温州 网站建设公司网站没有备案是不是违法的
  • 校内 实训网站 建设网站类网站开发
  • 佛山网站建设找千界如何避免网站被耍流量