展开全部
这个方法是有的。
(注:一般用结构体判断,所以下面的解释都是结构体型的。首先说明,我定义了一个结构体
struct stu{ char ch[maxlen];struct stu *next;};)
首先声明头文件malloc.h,即#included<malloc.h>
随后使用动态内存分配, 比如int *p;p=(struct stu*)malloc(sizeof(struct stu*) * m)。
-------以上是开辟内存单元
-------------------------------------------
接下来说说如何扩充内存单元
你讲:“如何用C语言做自动动态存储数据”,其实所谓的“自动动态存储数据”,关键是2点
1、怎么动态存储
2、怎么在存储单元不够用时扩充。
对于第1个问题,用链式结构就好了,这很简单,具体看看有关于介绍链表的书就好。不推荐《数据结构》,推荐《算法与数据结构》或《数据结构与算法分析》。
针对第2个问题,由于不知道你水平如何,所以现在只提一种简单有效的方法,那就是用if()语句做判断,例如前面的*p:if(p==NULL)
{ p2=(struct stu*)malloc(sizeof(struct stu*) * m*2);//<-内存扩大两倍
p->ch[maxlen]=p2->ch[maxlen];
}
这样就好了。(注意:maxlen这里在具体实现代码时要变。)
如果你觉得我的描述有点简单,咱们还可以继续讨论。如果觉得难了点,那你真的要好好了解数据结构与算法之间的关系了。
加油吧朋友!!!!!!!
(注:一般用结构体判断,所以下面的解释都是结构体型的。首先说明,我定义了一个结构体
struct stu{ char ch[maxlen];struct stu *next;};)
首先声明头文件malloc.h,即#included<malloc.h>
随后使用动态内存分配, 比如int *p;p=(struct stu*)malloc(sizeof(struct stu*) * m)。
-------以上是开辟内存单元
-------------------------------------------
接下来说说如何扩充内存单元
你讲:“如何用C语言做自动动态存储数据”,其实所谓的“自动动态存储数据”,关键是2点
1、怎么动态存储
2、怎么在存储单元不够用时扩充。
对于第1个问题,用链式结构就好了,这很简单,具体看看有关于介绍链表的书就好。不推荐《数据结构》,推荐《算法与数据结构》或《数据结构与算法分析》。
针对第2个问题,由于不知道你水平如何,所以现在只提一种简单有效的方法,那就是用if()语句做判断,例如前面的*p:if(p==NULL)
{ p2=(struct stu*)malloc(sizeof(struct stu*) * m*2);//<-内存扩大两倍
p->ch[maxlen]=p2->ch[maxlen];
}
这样就好了。(注意:maxlen这里在具体实现代码时要变。)
如果你觉得我的描述有点简单,咱们还可以继续讨论。如果觉得难了点,那你真的要好好了解数据结构与算法之间的关系了。
加油吧朋友!!!!!!!
光点科技
2023-08-15 广告
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
展开全部
一般用链表,可以动态地插入和删除节点;
typedef struct NODE
{
//你需要的数据成员
NODE *next; //用于连接下一个节点
}Node;
typedef struct NODE
{
//你需要的数据成员
NODE *next; //用于连接下一个节点
}Node;
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用链表做
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询