顺序表等相关概念请自行查阅资料,这里主要是实现。

注:

1.顺序表C语言实现;

2.按较简单的方式实现,主要帮助理解,可在此基础上修改,更加完善;

3.提供几个简单函数,可自行添加功能;

4.可用C++封装,得知STL中vector原理。

顺序表容量。

#define CAPACITY 20 //容量

顺序表结构体。

typedef struct
{
int *m_pHead; //指向数组头
int m_iSize; //大小
int m_iCapacity; //容量
}STABLE;

部分操作,可自行添加其他操作。

STABLE* createTable();
void appendElement(STABLE* pTable, int iElement);
void insertElement(STABLE* pTable, int iElement, int index);
void delElement(STABLE* pTable, int index);
int getAt(STABLE* pTable, int index);
void setAt(STABLE* pTable, int iElement, int index);
void showTable(STABLE* pTable);
void releaseMem(STABLE* pTable);

分配内存,元素个数为0。

STABLE* createTable()
{
STABLE *pTable = (STABLE*)malloc(sizeof(STABLE));
if(!pTable)
{
printf("动态内存分配失败!\n");
return pTable;
} pTable->m_pHead = (int*)malloc(sizeof(int) * CAPACITY);
if(!pTable->m_pHead)
{
printf("动态内存分配失败!\n");
return NULL;
} pTable->m_iSize = ;
pTable->m_iCapacity = CAPACITY; return pTable;
}

追加

void appendElement(STABLE* pTable, int iElement) 
{
    if(!pTable || !pTable->m_pHead)
    {
        printf("顺序表不存在!\n");
        return;
    }     if(pTable->m_iSize == pTable->m_iCapacity)
    {
        printf("顺序表已满!\n"); //可以重新分配内存 这里就不实现了 从简
        return;
    }
    
    pTable->m_pHead[pTable->m_iSize] = iElement;
    pTable->m_iSize++;
}

插入

void insertElement(STABLE* pTable, int iElement, int index)
{
    if(!pTable || !pTable->m_pHead)
    {
        printf("顺序表不存在!\n");
        return;
    }     if(pTable->m_iSize == pTable->m_iCapacity)
    {
        printf("顺序表已满!\n"); //可以重新分配内存 这里就不实现了 从简
        return;
    }     if(index < 0 || index > pTable->m_iSize)
    {
        printf("插入位置不合理!\n");
        return;
    }     //后移
    for(int i = pTable->m_iSize - 1; i >= index; i--)
    {
        pTable->m_pHead[i+1] = pTable->m_pHead[i];
    }
    pTable->m_pHead[index] = iElement;
    pTable->m_iSize++;
}

删除

void delElement(STABLE* pTable, int index)
{
if(!pTable || !pTable->m_pHead)
{
printf("顺序表不存在!\n");
return;
} if(pTable->m_iSize < )
{
printf("顺序表元素个数为0!\n");
return;
} if(index < || index > pTable->m_iSize - )
{
printf("删除元素位置不合理!\n");
return;
} //前移
for(int i = index; i < pTable->m_iSize - ; i++)
{
pTable->m_pHead[i] = pTable->m_pHead[i+];
} pTable->m_iSize--;
}

获取

int getAt(STABLE* pTable, int index)
{
if(!pTable || !pTable->m_pHead)
{
printf("顺序表不存在!\n");
return -;
} if(index < || index > pTable->m_iSize - )
{
printf("索引不合理!\n");
return -;
} return pTable->m_pHead[index];
}

修改

void setAt(STABLE* pTable, int iElement, int index)
{
if(!pTable || !pTable->m_pHead)
{
printf("顺序表不存在!\n");
return;
} if(index < || index > pTable->m_iSize - )
{
printf("索引不合理!\n");
return;
} pTable->m_pHead[index] = iElement;
}

打印所有元素。

void showTable(STABLE* pTable)
{
if(!pTable || !pTable->m_pHead)
{
printf("顺序表不存在!\n");
return;
} printf("容量:%d,大小:%d,打印元素:\n", pTable->m_iCapacity, pTable->m_iSize);
for(int i = ; i < pTable->m_iSize; i++)
printf("%d ", pTable->m_pHead[i]); printf("\n");
}

内存释放。

void releaseMem(STABLE* pTable)
{
if(!pTable)
{
printf("顺序表不存在!\n");
return;
} if(pTable->m_pHead)
free(pTable->m_pHead); free(pTable);
printf("内存释放成功!\n");
}

数据结构与算法之顺序表C语言实现的更多相关文章

  1. C:数据结构与算法之顺序表

    顺序表作为数据结构的开端,说明这里面很多基础要学,初学者一开始都会混淆,今天我们来一步一步来建立一个完整的顺序表,可以任我们控制的顺序表,首先先定义一个顺序表 /* Note:Your choice ...

  2. 数据结构与算法之顺序栈C语言实现

    顺序栈是一种特殊的顺序表,主要操作是入栈和出栈.将顺序表加一些特定限制,就成了顺序栈. 注: 1.顺序栈C语言实现: 2.按较简单的方式实现,主要帮助理解,可在此基础上修改,更加完善: 3.提供几个简 ...

  3. python基础下的数据结构与算法之顺序表

    一.什么是顺序表: 线性表的两种基本的实现模型: 1.将表中元素顺序地存放在一大块连续的存储区里,这样实现的表称为顺序表(或连续表).在这种实现中,元素间的顺序关系由它们的存储顺序自然表示. 2.将表 ...

  4. Java数据结构和算法 - 哈希表

    Q: 如何快速地存取员工的信息? A: 假设现在要写一个程序,存取一个公司的员工记录,这个小公司大约有1000个员工,每个员工记录需要1024个字节的存储空间,因此整个数据库的大小约为1MB.一般的计 ...

  5. 数据结构与算法(c++)——跳跃表(skip list)

    今天要介绍一个这样的数据结构: 单向链接 有序保存 支持添加.删除和检索操作 链表的元素查询接近线性时间 ——跳跃表 Skip List 一.普通链表 对于普通链接来说,越靠前的节点检索的时间花费越低 ...

  6. 【数据结构与算法】线性表操作(C++)

    #include <stdio.h> #define maxSize 100 //定义整型常量maxSize值为100 /*顺序表的结构体定义*/ typedef struct SqLis ...

  7. 实现数据结构与算法需要掌握的C语言

    我使用C语言并不频繁,一般都是用来实现数据结构与算法,因为面向过程的编程方式容易理解算法的原理,但是呢,如果很长时间没写算法,那么就意味着C语言的某些语法就生疏了,但是总有那么一些,在写算法的时候,特 ...

  8. 《数据结构》2.2顺序表(sequence list)

    //顺序表节点的定义 typedef struct { datatype data[MAXSIZE]; //数组容量的上限 int len; //记录最后一个元素的位置,相当于一个指针,表空时len= ...

  9. 顺序表C语言版

    #include <stdio.h> /* * 顺序表最多输入N个数 */ #define N 10 #define OK 1 #define ERROR -1 struct sequeu ...

随机推荐

  1. MySQL常见错误分析与解决方法总结

    MySQL常见错误分析与解决方法总结 一.Can't connect to MySQL server on 'localhost' (10061)翻译:不能连接到 localhost 上的mysql分 ...

  2. Javascript入门笔记1-script标签

    1.script标签在HTML文件中添加JavaScript代码. JavaScript代码只能写在HTML文件中吗?当然不是,我们可以把HTML文件和JS代码分开,并单独创建一个JavaScript ...

  3. Zeppelin interperter 模式设置总结图解1

    如有错漏,望请指正,不胜感激. 参考:[zeppelin官网]:https://zeppelin.apache.org/docs/latest/interpreter/spark.html#inter ...

  4. Laravel操作上传文件的方法

    1.获取上传的文件 $file=$request->file('file');2.获取上传文件的文件名(带后缀,如abc.png) $filename=$file->getClientOr ...

  5. JZOJ 3534. 【NOIP2013提高组day1】货车运输

    Description A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的 ...

  6. php结合redis实现高并发下的抢购、秒杀功能【转】

    抢购.秒杀是如今很常见的一个应用场景,主要需要解决的问题有两个:1 高并发对数据库产生的压力2 竞争状态下如何解决库存的正确减少("超卖"问题)对于第一个问题,已经很容易想到用缓存 ...

  7. PHP表单安全过滤和防注入 htmlspecialchars() 和test_input()

    什么是 htmlspecialchars() 函数? htmlspecialchars() 函数把特殊字符转换为 HTML 实体.这意味着 < 和 > 之类的 HTML 字符会被替换为 & ...

  8. J.U.C 系列 Tools之Executors

    上个章节说了Tools中的其他四个工具类,本节我们来看一看工具类中的老大Executors,为什么说它是老大,肯定是因为他的功能最多最强大. 一 Executors是什么 Executors 是一个线 ...

  9. python协程和IO多路复用

     协程介绍                                                                                                ...

  10. MyBatis---集合查询(一对多)

    这里的集合查询即一对多的数据联合查询.如一个用户多次登录的信息查询 要实现这样的联合查询需要在用户实体类中添加登录实体类的一个集合属性字段,表中不存在该字段. <resultMap id=&qu ...