变长数组列表ArrayList
简介:此数据结构定义为一个ArrayList结构体类型,维护了一个内部堆数组。通过realloc函数实现了数组容量自动扩充,每次扩充到原来的2倍。
通过函数指针实现了使用者根据自己的需求按条件按查找目标元素的功能,查找筛选函数需要使用者自行编写。
支持的主要操作:
追加Append
插入Insert
删除Delete
访问GetElement
写入SetElement
查找Find
FindAll
裁剪TrimToSize
销毁Destroy
/*
file : ArrayList.h
*/
#ifndef _ARRAYLIST_H_
#define _ARRAYLIST_H_
typedef int ElemType; //存储的数据的类型
typedef int(*FindFunc)(ElemType); //定义一个函数指针类型 FindFunc,作为查找函数 的类型
typedef struct {
ElemType *p_inner_arr; //指向数组第一个元素的指针
int length; //表中实际元素个数
int capacity; //表的容量
}ArrayList;
void InitList(ArrayList* plist,int c);
void TrimToSize(ArrayList* plist) ;
int Insert(ArrayList* plist,ElemType x,int index);
void Append(ArrayList* plist,ElemType x);
int Delete(ArrayList* plist,ElemType* px,int index);
ElemType GetElement(ArrayList*plist , int index);
void SetElement(ArrayList*plist , ElemType x, int index);
int IsEmpty(ArrayList *plist);
int Find(ArrayList *plist, FindFunc func);
ArrayList* FindAll(ArrayList *plist, FindFunc func);
void Destroy(ArrayList*plist);
#endif
/* file : ArrayList.cpp
*/
#include<stdlib.h>
#include "ArrayList.h"
/*初始化数组列表
*/
void InitList(ArrayList* plist,int c)
{
plist->capacity = c; //初始化容量
plist->length = ; //初始化实际长度
plist->p_inner_arr = (ElemType*)malloc(c * sizeof(ElemType)) ;
//分配初始内存空间
//假设这里malloc 总成功
}
/*裁剪多于的 没有存放数据的内存空间 。即length == capacity
*/
void TrimToSize(ArrayList* plist)
{
) return ;
if(plist->length < plist->capacity)
{ //realloc实现堆内存的大小调整,大小可增,也可以减,它会返回调整大小后的内存的新地址。重新赋值给p_inner_arr
plist->p_inner_arr = (ElemType*)realloc(plist->p_inner_arr,plist->length*sizeof(ElemType));
plist->capacity = plist->length;
}
}
/*追加或者插入都可以
增加失败返回 false
*/
int Insert(ArrayList* plist,ElemType x,int index)
{
|| index > (plist->length) ) //索引不合法
;
if(plist->length >= plist->capacity) //表已经饱和
{
plist->p_inner_arr = (ElemType*)realloc(plist->p_inner_arr, plist->length**sizeof(ElemType));
plist->capacity = plist->length*;
}
; i>=index ; --i )
{
plist->p_inner_arr[i+] = plist->p_inner_arr[i];
}
plist->p_inner_arr[index] = x; //插入
++(plist->length); //增加表长度
;
}
/* 追加
*/
void Append(ArrayList* plist,ElemType x)
{
if(plist->length >= plist->capacity) //表已经饱和,无法容纳
{
plist->p_inner_arr = (ElemType*)realloc(plist->p_inner_arr, plist->length**sizeof(ElemType));
plist->capacity = plist->length*;
}
plist->p_inner_arr[plist->length] = x;
++(plist->length);
return ;
}
/*删除某个元素
删除失败返回false
*/
int Delete(ArrayList* plist,ElemType* px,int index)
{
) ;
|| index > (plist->length-)) ;
if(px!=NULL) *px = (plist->p_inner_arr)[index];
/*数据结构的使用者可以选择是否需要保存
这个被删除的元素,不需要则传入NULL
*/
; ++i) //前移
{
plist->p_inner_arr[i] = plist->p_inner_arr[i+];
}
--(plist->length);
;
}
ElemType GetElement(ArrayList*plist , int index)
{
return plist->p_inner_arr[index];
}
void SetElement(ArrayList*plist , ElemType x, int index)
{
|| index> plist->length ) return ;
plist->p_inner_arr[index] = x;
}
//状态判断
int IsEmpty(ArrayList *plist)
{
;
}
/*按条件查找
条件函数由使用者自行编写,这个函数接受一个ElemType类型参数,并返回1 or 0
一旦找到了符合条件的元素,就返回它的索引,没找到,则返回 -1
*/
int Find(ArrayList *plist, FindFunc func)
{
; i<plist->length ; ++i)
{
if(func(plist->p_inner_arr[i]))
return i;
}
;
}
/* 按条件查找所有符合的元素
*/
ArrayList* FindAll(ArrayList *plist, FindFunc func)
{
ArrayList*tlist ; //新建一个Arraylist对象,用来保存符合条件的元素
InitList(tlist,) ;
; i<plist->length; ++i)
{
if(func(plist->p_inner_arr[i]))
Append(tlist,plist->p_inner_arr[i]);
}
) //没有找到任何符合要求的元素
{
Destroy(tlist);
return NULL;
}
TrimToSize(tlist);
return tlist;
}
void Destroy(ArrayList*plist)
{
free(plist->p_inner_arr);
plist->p_inner_arr = NULL;
plist->length=;
plist->capacity=;
}
心得:
1、还是面对对象好,主要优势很明显:数据对象的自描述性和自操作性,也就是一个数据的属性和操作都在"自己身"上找到,还有封装会使数据结构更加完美,安全。
2、数据结构需要的通用性要好,而C本身不支持泛型编程,但是在编写代码的时候可以优化代码的通用性,这样使用不同目标数据类型时,只需要做很少的修改。
3、还是C语言写起来有感觉些,简洁,自由,哈哈。
变长数组列表ArrayList的更多相关文章
- C++内存分配及变长数组的动态分配
//------------------------------------------------------------------------------------------------ 第 ...
- oracle:变长数组varray,嵌套表,集合
创建变长数组类型 ) ); 这个变长数组最多可以容纳两个数据,数据的类型为 varchar2(50) 更改元素类型的大小或精度 可以更改变长数组类型和嵌套表类型 元素的大小. ALTER TYPE ...
- C99新增内容之变长数组(VLA)
我们在使用多维数组是有一点,任何情况下只能省略第一维的长度.比如在函数中要传一个数组时,数组的行可以在函数调用时传递,当属数组的列却只能在能被预置在函数内部.看下面一个例子: #define COLS ...
- GCC 中零长数组与变长数组
前两天看程序,发现在某个函数中有下面这段程序: int n; //define a variable n int array[n]; //define an array with length n 在 ...
- C99新特性:变长数组(VLA)
C99标准引入了变长数组,它允许使用变量定义数组各维.例如您可以使用下面的声明: ; ; double sales[rows][cols]; // 一个变长数组(VLA) 变长数组有一些限制,它必须是 ...
- PL/SQL — 变长数组
PL/SQL变长数组是PL/SQL集合数据类型中的一种,其使用方法与PL/SQL嵌套表大同小异,唯一的区别则是变长数组的元素的最大个数是有限制的.也即是说变长数组的下标固定下限等于1,上限可以扩展.下 ...
- PL/SQL 嵌套表变长数组和索引表[转]
关于PL/SQL中这三种数组的介绍,不想写了.转一篇日志吧…… 链接:http://www.blogjava.net/decode360/archive/2008/08/08/280825.html ...
- c语言,变长数组
下面这个结构体,可以在malloc的时候指定数据data的长度,这样的形式就是变长数组:typedef struct{ int data_len; char data[0];//或char data[ ...
- C99中的变长数组(VLA)
处理二维数组的函数有一处可能不太容易理解,数组的行可以在函数调用的时候传递,但是数组的列却只能被预置在函数内部.例如下面这样的定义: #define COLS 4 int sum3d(int ar[] ...
随机推荐
- windows 8 系统部署IIS并发布网站
企业用户可以在已经部署了windows 8 的电脑中通过部署IIS服务器来发布自己公司的企业内部网站实现对企业的网络办公的管理工作. 准备篇 IIS的添加和运行 一.IIS的添加 1.请进入“控制面板 ...
- Assets/Sciprts/GameSciprt.js(97,46): BCE0044: expecting :, found ','.
function BuildDeck() { var totalRobots:int=4; var card:Object; var i:int; for(i=0;i<totalRobots;i ...
- BZOJ3750 : [POI2015]Pieczęć
枚举第一个位置,然后暴力检验. #include<cstdio> #define N 1010 int T,n,m,a,b,x,y,i,j,k,q[N*N][2],cnt;char s[N ...
- wp控件
导航控件 Silverlight的Windows Phone应用程序是基于一种可以让用户在不同页面内容间来回导航的页面模型.这个模型是基于其中的frame控件,而页面间的导航就是靠它. 下面的表格列出 ...
- More about Tair (NoSql)
一.前言 关于Tair的相关介绍请参照wiki(http://code.taobao.org/p/tair/wiki/index/)或者之前的博文,不再重复描述.区别于其它主流NoSql数据库,Tai ...
- java第一节课
1.安装 2.编写java程序 首先,新建一个文本文档:把后缀改成.java,然后起一个文件名,要是英文的,如:Hello. 然后,编辑,代码如下: class Hello { public stat ...
- linux用户和组管理
添加组groupadd sftp 把用户mysftp加入组sftp中:gpasswd -a mysftp sftp 把用户mysftp加入组sftp中:usermod -a -G sftp mysft ...
- Angular数据双向绑定
Angular数据双向绑定 AngularJS诞生于2009年,由Misko Hevery 等人创建,后为Google所收购.是一款优秀的前端JS框架,已经被用于Google的多款产品当中.Angul ...
- PHP多重判断删除文件函数
<?function delete_file($file) { if (file_exists($file)) { $delete = chmod ($file, ...
- 将MyApp.exe和Autorun.lnk添加到NK里,在project.bib文件内加入
1. 将应用程序和应用程序快捷方式添加到映像里,再将快捷方式添加到StartUp目录下,这样当系统运行后应用程序就能自动运行:2. 直接替换Wince的SHELL,即修改注册表: [HKEY_LOCA ...