c语言,数组集合、盗墓者是个丑奴儿

2024-01-12 03:59

本文主要是介绍c语言,数组集合、盗墓者是个丑奴儿,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

盗墓者是个丑奴儿,原

什么是集合?无限存储的容器,本次做无限存储的采用的数据结构是数组。无限存储[增]实现原理:通过数组的不断扩容,并更改数组的引用做到无限存储。其余方法[删,查,改,插]均是:通过操作数组下标进行实现。

 

注:c没有提供包装的object数据类型,于是本例数组集合以单个数据类型作数组集合。使用面向对象语言(如:Java)做数组集合也是一样的方法,可做参考。在文中使用typedef重定义了int*与int,本例以重定义类型为基础,方便数组集合的类型做修改。

#include <stdio.h>

#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <ctype.h>


#define str_l(arr) (sizeof(arr)/sizeof(arr[0]))       //计算数组长度
typedef int* TYPEP;        //重命名int *与int,方便迁移为其他数组类型的数组集合。
typedef int TYPE;


TYPE * arr=NULL;        //数组集合
int size=0;                    //数组总大小
int ind=0;                     //数组当前存储有多少个有效值
 

 

//参数值,作用:往数组集合添加值

//判断数组是否为null,为null申请并存值。如果不为null,判断数组是否存满。如果满了申请更大的数组,保留老值存储新值,

//替换引用

int add(int Elemen){
        if(arr==NULL){
                TYPE size_i=sizeof(TYPE)*3;
                arr=(TYPEP)malloc(size_i);
                arr[ind++]=Elemen;
                size=size_i/sizeof(TYPE);
                return 1;
        }else{
                if(ind<size){
                        arr[ind++]=Elemen;
                        return 1;
                }else{
                        TYPE arry[size];
                        memset(arry,0,sizeof(arry));
                        memcpy(arry,arr,size*sizeof(TYPE));
                        free(arr);
                        arr=(TYPEP)malloc(sizeof(TYPE)*size+3*sizeof(TYPE));
                        size=size+3;
                        memcpy(arr,arry,sizeof(arry));
                        arr[ind++]=Elemen;
                        return 1;
                }
        }
        return 0;

}

 

//判断传入的下标是否大于当前数组长度,判断是否有误

int validate(int index){
        if(index>size)
        return 0;
}
 

 

//参数下标,作用:删除数组集合这个下标的元素

int del(int index){
        if(validate(index)==0)
        return 0;
        int y=1;
        for(int i=0;i<ind-index-1;i++){
                arr[index+i]=arr[(index+(y++))];
        }
        arr[ind-1]=0;
        return 1;
}
 

 

//参数下标,作用:查找数组集合这个下标的值

int sel(int index){
        if(validate(index)==0)
        return 0;
        return arr[index];
}
 

 

//参数下标,作用:替换数组集合这个下标的值

int upd(int index,int value){
        if(validate(index)==0)
        return 0;
        arr[index]=value;
        return 1;
}
 

 

//参数下标,作用:往这个下标后插入值

int ins(int index,int value){
        if(validate(index)==0)
        return 0;
        for(int i=ind;i>index;i--){
                arr[i]=arr[i-1];
        }
        arr[index]=value;
        return 1;

}

 

//测试

int main(void){
        int a=add(7);
        int b=add(6);
        int c=add(5);
        int d=add(4);
        int e=add(3);
        int f=add(2);
        int g=add(1);

        printf("state=%d %d %d %d %d %d %d \n",a,b,c,d,e,f,g);

        del(3);

        ins(0,9);

        for(int i=0;i<size;i++)
        printf("value=%d \n",arr[i]);

        printf("select=%d\n",sel(4));
        upd(4,9);
        printf("select=%d\n",sel(4));

        return 0;

}

 

运行结果:

add返回添加结果,state变量接收打印,都打印1表示入值成功。集合有效值为:7654321。中途删除了第3个下标,集合有效值为:765321,ins下标0插入值,集合有效值为:9765321。upd更改第4个下标的值,sel在查询第4个下标。值被覆盖为9

0为待数据填充,为数组扩容初始的值。到此测试完毕。

 

这篇关于c语言,数组集合、盗墓者是个丑奴儿的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/596734

相关文章

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

C语言逗号运算符和逗号表达式的使用小结

《C语言逗号运算符和逗号表达式的使用小结》本文详细介绍了C语言中的逗号运算符和逗号表达式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接其一般形式为:表达

Go语言实现桥接模式

《Go语言实现桥接模式》桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化,本文就来介绍一下了Go语言实现桥接模式,感兴趣的可以了解一下... 目录简介核心概念为什么使用桥接模式?应用场景案例分析步骤一:定义实现接口步骤二:创建具体实现类步骤三:定义抽象类步骤四:创建扩展抽象类步

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

GO语言zap日志库理解和使用方法示例

《GO语言zap日志库理解和使用方法示例》Zap是一个高性能、结构化日志库,专为Go语言设计,它由Uber开源,并且在Go社区中非常受欢迎,:本文主要介绍GO语言zap日志库理解和使用方法的相关资... 目录1. zap日志库介绍2.安装zap库3.配置日志记录器3.1 Logger3.2 Sugared

Go语言中如何进行数据库查询操作

《Go语言中如何进行数据库查询操作》在Go语言中,与数据库交互通常通过使用数据库驱动来实现,Go语言支持多种数据库,如MySQL、PostgreSQL、SQLite等,每种数据库都有其对应的官方或第三... 查询函数QueryRow和Query详细对比特性QueryRowQuery返回值数量1个:*sql

GO语言中gox交叉编译的实现

《GO语言中gox交叉编译的实现》本文主要介绍了GO语言中gox交叉编译的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、安装二、使用三、遇到的问题1、开启CGO2、修改环境变量最近在工作中使用GO语言进行编码开发,因

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础