1、前面讲了如何使用动态分配内存的方式创建ADT链表,但是链表只是一种数据结构,涉及到具体的应用时,我们需要根据具体的要求来对链表进行一定的修改,这地方我使用多项式的例子来进行讲解。
2、涉及到链表的相关的操作前面已经进行了细致的讲解,这里不再多说。对于多项式,要满足+、—、*、/、四则基本运算。使用链表作为多项式的存储结构,实现上述四则基板运算是今天的目标。
3、链表的构建
3.1 多项式的每一项由系数和指数构成,首先需要构建满足这一要求的结构体:
typedef struct //项的表示,多项式的项作为LinkList的数据元素
{
float coef;//系数
int expn;//指数
}Item, ElemType;//两个类型名:Item用于这个ADT(抽象数据类型)
以上面的数据类型,构建节点类型,形成链表的基本节点
typedef struct _LinkNode /* 结点类型 */
{
ElemType data;
struct _LinkNode *pNext;
}LNode,*pLink,*Position;
最终构建出如下的链表
typedef struct LinkList /* 链表类型 */
{
pLink head,tail; /* 分别指向线性链表中的头结点和最后一个结点 */
int nLenth; /* 指示线性链表中数据元素的个数 */
}LinkList;
ty