如何用C语言做自动动态存储数据

用于超市结算购买物品的存储数据... 用于超市结算购买物品的存储数据 展开
 我来答
weidu23
2012-04-18 · TA获得超过199个赞
知道答主
回答量:88
采纳率:0%
帮助的人:70.5万
展开全部
这个方法是有的。
(注:一般用结构体判断,所以下面的解释都是结构体型的。首先说明,我定义了一个结构体
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这里在具体实现代码时要变。)
如果你觉得我的描述有点简单,咱们还可以继续讨论。如果觉得难了点,那你真的要好好了解数据结构与算法之间的关系了。
加油吧朋友!!!!!!!
百度网友98f95cc50
2012-04-17 · TA获得超过842个赞
知道小有建树答主
回答量:167
采纳率:0%
帮助的人:265万
展开全部
一般用链表,可以动态地插入和删除节点;
typedef struct NODE
{
//你需要的数据成员
NODE *next; //用于连接下一个节点
}Node;
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lyhfylc
2012-04-18 · 超过15用户采纳过TA的回答
知道答主
回答量:92
采纳率:0%
帮助的人:36.8万
展开全部
用链表做
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式