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

相关文章

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

Go语言中使用JWT进行身份验证的几种方式

《Go语言中使用JWT进行身份验证的几种方式》本文主要介绍了Go语言中使用JWT进行身份验证的几种方式,包括dgrijalva/jwt-go、golang-jwt/jwt、lestrrat-go/jw... 目录简介1. github.com/dgrijalva/jwt-go安装:使用示例:解释:2. gi

Go 语言中的 Struct Tag 的用法详解

《Go语言中的StructTag的用法详解》在Go语言中,结构体字段标签(StructTag)是一种用于给字段添加元信息(metadata)的机制,常用于序列化(如JSON、XML)、ORM映... 目录一、结构体标签的基本语法二、json:"token"的具体含义三、常见的标签格式变体四、使用示例五、使用

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细