C : Arrary的自定义内部实现源码 数组

struct Arr
{
    int *pBase; // 存储的是数组第一个元素的地址
    int len;    // 数组所能容纳的最大元素的个数
    int cnt;    // 当前数组有效元素的个数
    //int increment;//自动增长因子
};
void init_Arr(struct Arr *arr, int lenght);
bool append_Arr(struct Arr *arr, int value);
bool insert_Arr(struct Arr *arr, int value, int index); // index:下标
bool delete_Arr(struct Arr *arr, int *value, int index);
bool is_empty(struct Arr *arr);
bool is_full(struct Arr *arr);
void sort_Arr(struct Arr *arr); // 排序
void show_Arr(struct Arr *arr);
void innversion_Arr(struct Arr *arr); // 倒置


int main()
{
    int valu;
    struct Arr arr;
    init_Arr(&arr, 8);
    append_Arr(&arr, 4023);
    append_Arr(&arr, 100);
    append_Arr(&arr, 2333);
    append_Arr(&arr, 2333);
    append_Arr(&arr, 2333);
    append_Arr(&arr, 2313);
    show_Arr(&arr);
    insert_Arr(&arr, 123, 2);
    show_Arr(&arr);
    delete_Arr(&arr, &valu, 2);
    show_Arr(&arr);
    innversion_Arr(&arr);
    show_Arr(&arr);
    sort_Arr(&arr);
    show_Arr(&arr);
    return 0;
    
}


void init_Arr(struct Arr *arr, int lenght)
{
    arr->pBase = malloc(sizeof(int)* lenght);
    if (NULL == arr->pBase) {
        printf("内存分配失败");
        exit(-1);
    } else {
        arr->len = lenght;
        arr->cnt = 0;
    }
    return;
}
bool append_Arr(struct Arr *arr, int value)
{
    if (is_full(arr))
        return false;
    arr->pBase[arr->cnt] = value;
    arr->cnt++;
    return true;
}
bool insert_Arr(struct Arr *arr, int value, int index)
{
    if (is_full(arr))
        return false;
    
    if (index < 0 || index > arr->cnt) {
        printf("请输入有效位置");
        return false;
    }
    
    for (int i = arr->cnt - 1; i >= index; -- i) {
        arr->pBase[i + 1] = arr->pBase[i];
    }
    arr->pBase[index] = value;
    arr->cnt ++;
    return true;
}
bool delete_Arr(struct Arr *arr, int *value, int index)
{
    if (is_empty(arr))
        return false;
    if (index > arr->cnt - 1 || index < 0) {
        printf("请输入合法位置");
        return false;
    }
    *value = arr->pBase[index];
    for (int i = index; i < arr->cnt - 1; i ++) {
        arr->pBase[i] = arr->pBase[i + 1];
    }
    arr->cnt --;
    return true;
}
bool is_empty(struct Arr *arr)
{
    if (0 == arr->cnt) {
        printf("数组为空\n");
        return true;
    }
    return false;
}
bool is_full(struct Arr *arr)
{
    if (arr->cnt == arr->len) {
        printf("内存已满");
        return true;
    }
    return false;
}
void sort_Arr(struct Arr *arr)
{
    int a, i, j;
    for (i = 0; i <arr->cnt; i ++) {
        for (j = i + 1; j < arr->cnt; j ++) {
            if (arr->pBase[i] > arr->pBase[j]) {
                a = arr->pBase[i];
                arr->pBase[i] = arr->pBase[j];
                arr->pBase[j] = a;
            }
        }
    }
}
void show_Arr(struct Arr *arr)
{
    if (is_empty(arr)) {
        printf("数组为空\n");
    } else {
        for (int i = 0; i < arr->cnt; i ++) {
            printf("%d\n", arr->pBase[i]);
            
        }
    }
    printf("\n");
}
void innversion_Arr(struct Arr *arr)
{
    int i = 0;
    int j = arr->cnt - 1;
    int a;
    while (i < j) {
        a = arr->pBase[i];
        arr->pBase[i] = arr->pBase[j];
        arr->pBase[j] = a;
        ++i;
        --j;
    }
    return;
}

这里是自定义的数组的实现过程,可以参考

【为什么还需要学习C++?】 你是否接触很多语言,但从来没有了解过编程语言的本质?你是否想成为一名资深开发人员,想开发别人做不了的高性能程序?你是否经常想要窥探大型企业级开发工程的思路,但苦于没有基础只能望洋兴叹? 那么C++就是你个人能力提升,职业之路进阶的不二之选。【课程特色】 1.课程共19大章节,239课时内容,涵盖数据结构、函数、类、指针、标准库全部知识体系。2.带你从知识与思想的层面从0构建C++知识框架,分析大型项目实践思路,为你打下坚实的基础。3.李宁老师结合4大国外顶级C++著作的精华为大家推出的《征服C++11》课程。【学完后我将达到什么水平?】 1.对C++的各个知识能够熟练配置、开发、部署;2.吊打一切关于C++的笔试面试题;3.面向物联网的“嵌入式”和面向大型化的“分布式”开发,掌握职业钥匙,把握行业先机。【面向人群】 1.希望一站式快速入门的C++初学者; 2.希望快速学习 C++、掌握编程要义、修炼内功的开发者; 3.有志于挑战更高级的开发项目,成为资深开发的工程师。 【课程设计】 本课程包含3大模块基础篇本篇主要讲解c++的基础概念,包含数据类型、运算符等基本语法,数组、指针、字符串等基本词法,循环、函数、类等基本句法等。进阶篇本篇主要讲解编程中常用的一些技能,包含类的高级技术、类的继承、编译链接和命名空间等。提升篇:本篇可以帮助学员更加高效的进行c++开发,其中包含类型转换、文件操作、异常处理、代码重用等内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值