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

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;
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 数组在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式组织起来。这些按序排列的同类数据元素的集合称...
    朱森阅读 9,585评论 2 13
  • 指针是C语言中广泛使用的一种数据类型。 运用指针编程是C语言最主要的风格之一。利用指针变量可以表示各种数据结构; ...
    朱森阅读 8,828评论 3 44
  • 1、算法的概念 (1)概念:是指解题方案的准确而完整的描述。 【考题1】在计算机中,算法是指() A查询方法B加工...
    成都小菜阅读 5,727评论 0 15
  • 我总觉得大家都是好人,而自己还不够好。——序 凌晨四点,蚊香灭了,被蚊子咬醒。我好像不管在哪里,都特别讨蚊子喜欢,...
    井鼐阅读 3,297评论 0 1

友情链接更多精彩内容