美文网首页数据结构
C语言实现顺序存储结构(数组)

C语言实现顺序存储结构(数组)

作者: IdeaDeTechCreat | 来源:发表于2017-09-06 11:05 被阅读0次

C语言实现顺序存储结构(数组)

#include <stdio. h>
#include <malloc.h>
#include <stdlib.h>

struct Array
{
    int* pBase;     //数组首元素地址
    int length;     //数组总长度
    int cnt;        //数组当前元素个数
};

//数组初始化
void init_arr(struct Array * pArr, int length)
{
    pArr->pBase = (int*)malloc(sizeof(int) * length);
    if (pArr->pBase == NULL)
    {
        printf("内存分配失败!\n");
        exit(-1);
    }
    else
    {
        pArr->length = length;
        pArr->cnt = 0;
    }
}

//数组是否为空
int is_empty(struct Array *pArr)
{
    if (pArr->cnt == 0)
    {
        return 0;
    }
    return -1;
}


//数组是否已满
int is_full(struct Array *pArr)
{
    if (pArr->cnt == pArr->length)
    {
        printf("数组已满\n");
        return 0;
    }
    return -1;
}

//数组追加
int append(struct Array *pArr, int e)
{
    if ( is_full(pArr) == 0 )
    {
        return -1;
    }
    else
    {
        pArr->pBase[(pArr->cnt)++] = e;
    }
}

//在pos之前插入元素e
int insert(struct Array *pArr, int pos, int e)
{
    int i;
    if ( is_full(pArr) == 0 )
    {
        return -1;
    }
    if (pos < 1 || pos > pArr->cnt+1)
    {
        printf("位置错误,插入失败!\n");
        return -1;
    }
    else
    {
        for (i=pArr->cnt-1; i>=pos-1; i--)
        {
            pArr->pBase[i + 1] = pArr->pBase[i];
        }
        pArr->pBase[pos - 1] = e;
        pArr->cnt++;
    }
}

//移除pos位置的元素
int remove_element(struct Array * pArr, int pos)
{
    int i;
    if (is_empty(pArr) == 0)
    {
        printf("数组为空,删除失败!\n");
        return -1;
    }
    if (pos < 1 || pos > pArr->cnt)
    {
        printf("位置错误,删除失败!\n");
        return -1;
    }
    for (i=pos; i<=pArr->cnt-1; i++)
    {
        pArr->pBase[i - 1] = pArr->pBase[i];
    }
    pArr->cnt--;
    return 0;
}

//数组遍历
void traverse(struct Array* pArr)
{
    int i;
    for (i=0; i<pArr->cnt; i++)
    {
        printf("%d ", pArr->pBase[i]);
    }
    printf("\n");
}

//数组倒置
void inverse(struct Array *pArr)
{
    int i=0, j=pArr->cnt-1, t;
    while (i < j)
    {
        t = pArr->pBase[i];
        pArr->pBase[i] = pArr->pBase[j];
        pArr->pBase[j] = t;
        i++;
        j--;
    }
}

int main()
{
    struct Array array;
    init_arr(&array, 5);

    append(&array, 1);
    append(&array, 2);
    append(&array, 3);
    append(&array, 4);
    insert(&array, 5, 0);
    traverse(&array);
    remove_element(&array, 5);
    traverse(&array);

    return 0;
}

相关文章

  • C语言实现顺序存储结构(数组)

    C语言实现顺序存储结构(数组)

  • C++线性表的链式存储结构

    C++实现线性表的链式存储结构: 为了解决顺序存储不足:用线性表另外一种结构-链式存储。在顺序存储结构(数组描述)...

  • 0基础学习C语言第七章:数组(1)

    C数组 C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,...

  • java数据结构与算法之顺序表与链表深入分析

    一、线性表的顺序存储设计与实现(顺序表) 1.1 顺序存储结构的设计原理概要 顺序存储结构底层是利用数组来实现的,...

  • C语言基础教程之数组

    C 数组 C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它...

  • C语言学习五 — 数组与枚举

    数组 C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往...

  • 线性表之顺序存储结构

    线性表=顺序存储结构 +链式存储 结构 顺序存储结构:物理上连续(arraylist、数组) 增删改查排序 数组 ...

  • 数据结构基础--顺序栈

    顺序栈的概念:顺序栈是栈的顺序实现。顺序栈是指利用顺序存储结构实现的栈。采用地址连续的存储空间(数组)依次存储栈中...

  • 「数据结构 一」C 语言实现顺序表

    作者原创,转载请注明出处。 个人博客:renzhe.name 用 C 语言实现顺序存储结构的线性表,即顺序表。 下...

  • C语言----数组

    C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往被认为...

网友评论

    本文标题:C语言实现顺序存储结构(数组)

    本文链接:https://www.haomeiwen.com/subject/oemmjxtx.html