主要介绍循环链表和双向循环链表
2-1
对于一非空的循环单链表,h
和p
分别指向链表的头、尾结点,则有()
循环单链表判空:
设头结点front,尾节点rear:
(front->next = front),rear->next = rear;
2-2
在双向循环链表结点p
之后插入s
的语句是
过程就是,画个如下的图,然后按照选项给出的数据,挨个尝试,
当然,对于这类题目,记住一个点,可以大大减少选择难度:
最后一个一定是: p->(next) = s;
翻译成通用的就是,两个操作点的直接关系,放在最后!
2-4
某线性表中最常用的操作是在最后一个元素之后插入一个元素和删除第一个元素,则采用什么存储方式最节省运算时间?
设尾指针为 rear,尾部插入p,rear->next = p,rear = rear-next; 复杂度O(1)
删除第一个元素,rear->next = rear->next->next,复杂度O(1)
2-5
若某表最常用的操作是在最后一个结点之后插入一个结点或删除最后一个结点。则采用哪种存储方式最节省运算时间
头结点设为front;
最后一个节点插入;front->prior->next = p,p->prior = front->prior,p->next=front,front->prior=p;,复杂度O(1)
删除尾节点:front->prior->prior->next=front,front->prior = front->prior->prior;复杂度O(1)
这种题型就是想法设法,把几种操作的时间复杂度求解出来,然后进行比对,选择出正确答案;
2-18
已知指针ha和hb分别是两个单链表的头指针,下列算法将这两个链表首尾相连在一起,并形成一个循环链表(即ha的最后一个结点链接hb的第一个结点,hb的最后一个结点指向ha),返回该循环链表的头指针。请将该算法补充完整。
typedef struct node{
ElemType data;
struct node *next;
}LNode;
LNode *merge(LNode *ha, LNode *hb) {
LNode *p=ha;
if (ha==NULL || hb==NULL) {
cout<<”one or two link lists are empty!”<<endl;
return NULL;
}
while ( p->next!=NULL )
p=p->next;
p->next=hb;
while ( p->next!=NULL )
p=p->next;
__________
}
这种类型的题目,先把代码里面最后的指针位置弄清楚,代码里进行的操作已经把ha , hb 连接了起来,p现在指向hb 尾节点,你的目的是实现循环,p->next = ha;这是候的p->next正好是循环链表的头指针 , return p->next!==ha;
2-21
采用多项式的非零项链式存储表示法,如果两个多项式的非零项分别为N1和N2个,最高项指数分别为M1和M2,则实现两个多项式相乘的时间复杂度是()
数学问题,非零项*和