3个回答
展开全部
这个方法是有的。
(注:一般用结构体判断,所以下面的解释都是结构体型的。首先说明,我定义了一个结构体
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这里在具体实现代码时要变。)
如果你觉得我的描述有点简单,咱们还可以继续讨论。如果觉得难了点,那你真的要好好了解数据结构与算法之间的关系了。
加油吧朋友!!!!!!!
展开全部
一般用链表,可以动态地插入和删除节点;
typedef struct NODE
{
//你需要的数据成员
NODE *next; //用于连接下一个节点
}Node;
typedef struct NODE
{
//你需要的数据成员
NODE *next; //用于连接下一个节点
}Node;
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用链表做
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询