struct goods { char name [SIZE];//货物名 int count;//货物数量 float price;//货物价格 }; typedef struct goods dataType; //定义一个结构体 typedef struct list { dataType data; struct list *pNext; }LIST; LIST lis; /* 函数名:creation 函数功能:创建一个空结点 函数参数:无 函数返回值:创建成功返回结点的地址,失败返回NULL */ LIST * creation ( ) { //定义指针变量 LIST *pList = NULL; //申请空间 pList = ( LIST * ) malloc ( sizeof ( LIST ) ); //判断,初始化 if ( NULL == pList ) { return NULL; } memset ( pList, 0, sizeof ( LIST ) ); return pList; } /** * 增加商品 * @param name 商品名 * @param count 数量 * @param p 节点 * @return 成功则返回true */ bool add_goods(char name[],int count,LIST *p){ if ( NULL == p ) { return false; } //赋值 strcpy(p->data.name,name); p->data.count = count; return true; }
时间: 2023-08-08 19:06:10 浏览: 108
这段代码定义了一个结构体 dataType,其中包含了货物名货物数量和货物价格三个属性。后定义了一个链表结构体 LIST,其中包含了一个 dataType 类型的数据域和一个指向下一个节点的指针。接着定义了一个 LIST 类型的全局变量 lis。
接下来是一个名为 creation 的函数,其作用是创建一个空节点并返回该节点的地址。首先定义了一个 LIST 指针变量 pList,并动态分配了一个 LIST 结构体大小的内存空间并将其地址赋值给 pList。然后判断 pList 是否分配成功,如果不成功则返回 NULL。最后将 pList 清零并返回 pList 的地址。
接下来是一个名为 add_goods 的函数,该函数用于向链表中添加一个货物。其参数为一个商品名 name、一个数量 count 和一个指向链表节点的指针 p。首先判断 p 是否为空,如果为空则返回假。然后将 name 和 count 赋值给 p 的 data 属性,最后返回真表示添加成功。
阅读全文