C.Interface.And.Implementations—sequence的实现

2024-08-24 18:18

本文主要是介绍C.Interface.And.Implementations—sequence的实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、A sequence holds  N  values associated with the integer indices zero through N−1 when  N is positive. 

2、An empty sequence holds no values. 

3、Like arrays, values in a sequence may be accessed by indexing; 

4、they can also be added to or removed from either end of a sequence. 

5、Sequences expand automatically as necessary to accommodate their contents. Values are pointers.

6、they can be used as arrays, lists, stacks, queues, and deques, and they often subsume the facilities of separate
      ADTs for these data structures.


sequence底层数据结构如下图所示:

                    

其中左边部分阴影为上一节“dynamic array”,length为sequence中目前的元素总共数目,head为array中第一个元素的位置。可以看出,通过循环的dynamic array来实现sequence的。


==========================seq.h=============================

#ifndef SEQ_INCLUDED
#define SEQ_INCLUDED#define T Seq_T
typedef struct T *T;//exported functions
extern T      Seq_new   (int hint);
extern T      Seq_seq   (void *x, ...);
extern void   Seq_free  (T *seq);
extern int    Seq_length(T seq);
extern void  *Seq_get   (T seq, int i);
extern void  *Seq_put   (T seq, int i, void *x);
extern void  *Seq_addlo (T seq, void *x);
extern void  *Seq_addhi (T seq, void *x);
extern void  *Seq_remlo (T seq);
extern void  *Seq_remhi (T seq);#undef T
#endif

======================seq.c==========================

#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
#include "assert.h"
#include "seq.h"
#include "array.h"
#include "arrayrep.h"
#include "mem.h"#define T Seq_Tstruct T{struct Array_T  array;int length;int head;
};//static functions
static void expand(T seq){int n = seq->array.length;Array_resize(&seq->array, 2*n);if(seq->head > 0){void **old = &((void **)seq->array.array)[seq->head];memcpy(old+n, old, (n-seq->head)*sizeof(void *));seq->head += n;}
}//functions
T Seq_new(int hint){T seq;assert(hint >= 0);NEW0(seq);if(hint == 0)hint = 16;ArrayRep_init(&seq->array, hint, sizeof(void *),ALLOC(hint*sizeof(void *)));return seq;
}T Seq_seq(void *x, ...){va_list ap;T seq = Seq_new(0);va_start(ap, x);for( ; x; x = va_arg(ap, void *))Seq_addhi(seq, x);va_end(ap);return seq;
}void Seq_free(T *seq){assert(seq && *seq);assert((void *)*seq == (void *)&(*seq)->array);Array_free((Array_T *)seq);
}int Seq_length(T seq){assert(seq);return seq->length;
}void *Seq_get(T seq, int i){assert(seq);assert(i >= 0 && i < seq->length);return ((void **)seq->array.array)[(seq->head + i)%seq->array.length];
}void *Seq_put(T seq, int i, void *x){void *prev;assert(seq);assert(i >= 0 && i < seq->length);prev = ((void **)seq->array.array)[(seq->head + i)%seq->array.length];((void **)seq->array.array)[(seq->head + i)%seq->array.length] = x;return prev;
}void *Seq_remhi(T seq){int i;assert(seq);assert(seq->length > 0);i = --seq->length;return ((void **)seq->array.array)[(seq->head+i)%seq->array.length];
}void *Seq_remlo(T seq){int i = 0;void *x;assert(seq);assert(seq->length > 0);x = ((void **)seq->array.array)[(seq->head+i)%seq->array.length];seq->head = (seq->head + 1)%seq->array.length;--seq->length;return x;
}void *Seq_addhi(T seq, void *x){int i;assert(seq);if(seq->length == seq->array.length)expand(seq);i = seq->length++;return ((void **)seq->array.array)[(seq->head+i)%seq->array.length] = x;
}void *Seq_addlo(T seq, void *x){int i = 0;assert(seq);if(seq->length == seq->array.length)expand(seq);if(--seq->head < 0)seq->head = seq->array.length-1;seq->length++;return ((void **)seq->array.array)[(seq->head+i)%seq->array.length] = x;
}


这篇关于C.Interface.And.Implementations—sequence的实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103237

相关文章

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分