链表知识点
1.1单链表基础知识
- 单链表的每个节点至少包含以下哪个部分:( )
A. 数据域
B. 指针域
C. 数据域和指针域
D. 索引域
- 在单链表中,通常使用哪个指针来访问链表的第一个节点:( )
A. 前驱指针
B. 后继指针
C. 头指针
D. 尾指针
- 单链表的插入操作时间复杂度为:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 在单链表中,查找某个节点的时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 单链表中删除一个节点的时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 对于一个含有 n 个节点的单链表,表头指针指向第一个节点,要删除第 k 个节点,最坏情况下需要移动几个节点:( )
A. k
B. n-k
C. k-1
D. n
- 在单链表中,如果给定了某个节点的指针,删除该节点的操作时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 在单链表中,以下哪种操作最容易实现:( )
A. 在任意位置插入节点
B. 在任意位置删除节点
C. 查找任意节点
D. 在表头插入节点
- 如果要在单链表中实现从表尾删除节点的操作,通常需要的额外信息是:( )
A. 头指针
B. 尾指针
C. 前驱指针
D. 数据域
- 若单链表中只给定了头指针,以下哪种操作最难实现:( )
A. 在表头插入节点
B. 在表尾插入节点
C. 在表尾删除节点
D. 查找某个节点
- 对于单链表,以下说法正确的是:( )
A. 可以随机访问任意节点
B. 删除某节点后,指针会自动调整
C. 查找节点需要遍历链表
D. 插入节点后,需要调整所有节点的指针
- 单链表中的节点通过什么方式连接在一起:( )
A. 数据域
B. 指针域
C. 下标
D. 索引
- 在单链表中插入一个节点时,最少需要多少次指针操作:( )
A. 1
B. 2
C. 3
D. 4
- 单链表的尾节点的指针通常指向:( )
A. 头节点
B. NULL
C. 下一个节点
D. 自身
- 如果想逆序遍历单链表,最合适的解决方案是:( )
A. 使用递归
B. 使用栈
C. 双向链表
D. 哈希表
- 单链表的特点不包括:( )
A. 动态分配内存
B. 节点数不固定
C. 支持双向访问
D. 节点可以不连续存储
- 单链表的插入和删除操作是否会影响链表中其他节点的位置:( )
A. 会
B. 不会
C. 取决于链表的长度
D. 取决于节点的插入/删除位置
- 单链表中的表头插入操作所需时间是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 若要判断单链表是否为空表,最有效的办法是检查:( )
A. 数据域是否为空
B. 头指针是否为 NULL
C. 尾指针是否为 NULL
D. 链表长度是否为 0
- 在单链表中,如何有效地删除链表中的所有节点:( )
A. 遍历链表删除每个节点
B. 将头指针置为 NULL
C. 直接删除头节点
D. 释放链表的内存空间
1.2单链表解析
- 单链表的每个节点至少包含以下哪个部分:( )
A. 数据域
B. 指针域
C. 数据域和指针域
D. 索引域
解析:正确答案是 C。单链表的每个节点必须包含数据域和指针域。数据域用于存储节点的实际数据,而指针域用于存储下一个节点的地址,从而将各个节点连接起来形成链表。
- 在单链表中,通常使用哪个指针来访问链表的第一个节点:( )
A. 前驱指针
B. 后继指针
C. 头指针
D. 尾指针
解析:正确答案是 C。头指针是指向链表第一个节点的指针,通过头指针可以访问整个链表。前驱和后继指针通常用于双向链表,而尾指针(如果有的话)指向最后一个节点。
- 单链表的插入操作时间复杂度为:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
解析:正确答案是 B(选最坏的时间复杂度),取决于具体情况。在链表头部插入节点的时间复杂度是 O(1),因为不需要遍历链表。但如果在链表中间或尾部插入节点,需要先遍历到指定位置,时间复杂度为 O(n)。
- 在单链表中,查找某个节点的时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
解析:正确答案是 B。在单链表中查找节点需要从头开始遍历,直到找到目标节点或到达链表末尾,最坏情况下需要遍历整个链表,因此时间复杂度为 O(n)。
- 单链表中删除一个节点的时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
解析:正确答案是 A 和 B,取决于具体情况。删除头节点的时间复杂度是 O(1)。但如果要删除其他位置的节点,需要先遍历到该节点的前一个节点,时间复杂度为 O(n)。
- 对于一个含有 n 个节点的单链表,表头指针指向第一个节点,要删除第 k 个节点,最坏情况下需要移动几个节点:( )
A. k
B. n-k
C. k-1
D. n
解析:正确答案是 C。要删除第 k 个节点,需要找到第 k-1 个节点(即要删除节点的前一个节点)。因此,最坏情况下需要移动 k-1 个节点。
- 在单链表中,如果给定了某个节点的指针,删除该节点的操作时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
解析:正确答案是 A。如果已经给定了要删除节点的指针,可以通过将下一个节点的数据复制到当前节点,然后删除下一个节点来实现。这个操作不需要遍历链表,因此时间复杂度为 O(1)。
- 在单链表中,以下哪种操作最容易实现:( )
A. 在任意位置插入节点
B. 在任意位置删除节点
C. 查找任意节点
D. 在表头插入节点
解析:正确答案是 D。在表头插入节点是最简单的操作,只需要创建新节点,将其 next 指针指向原来的头节点,然后更新头指针即可,时间复杂度为 O(1)。
- 如果要在单链表中实现从表尾删除节点的操作,通常需要的额外信息是:( )
A. 头指针
B. 尾指针
C. 前驱指针
D. 数据域
解析:正确答案是 C。要从表尾删除节点,需要知道倒数第二个节点(即最后一个节点的前驱节点)。通常需要遍历链表找到这个节点,除非维护了一个指向倒数第二个节点的指针。
……
解析:正确答案是 C。在表尾删除节点需要找到倒数第二个节点,这需要遍历整个链表。而且,由于只有头指针,没有直接访问最后两个节点的方法,使得这个操作特别困难。
- 对于单链表,以下说法正确的是:( )
A. 可以随机访问任意节点
B. 删除某节点后,指针会自动调整
C. 查找节点需要遍历链表
D. 插入节点后,需要调整所有节点的指针
解析:正确答案是 C。单链表不支持随机访问,删除或插入节点后需要手动调整相关指针,而不是自动调整。查找节点确实需要从头遍历链表,这是正确的说法。
- 单链表中的节点通过什么方式连接在一起:( )
A. 数据域
B. 指针域
C. 下标
D. 索引
解析:正确答案是 B。单链表中的节点通过指针域连接在一起。每个节点的指针域存储下一个节点的地址,形成了节点之间的链接。
- 在单链表中插入一个节点时,最少需要多少次指针操作:( )
A. 1
B. 2
C. 3
D. 4
解析:正确答案是 B。插入一个节点至少需要两次指针操作:一次是将新节点的 next 指针指向下一个节点,另一次是将前一个节点的 next 指针指向新节点。
- 单链表的尾节点的指针通常指向:( )
A. 头节点
B. NULL
C. 下一个节点
D. 自身
解析:正确答案是 B。在单链表中,最后一个节点(尾节点)的 next 指针通常指向 NULL,表示链表的结束。
- 如果想逆序遍历单链表,最合适的解决方案是:( )
A. 使用递归
B. 使用栈
C. 双向链表
D. 哈希表
解析:正确答案是 B。对于单链表,使用栈是逆序遍历的最合适方法。可以先将所有节点压入栈中,然后依次弹出,实现逆序遍历。递归也是可行的,但可能会导致栈溢出。
- 单链表的特点不包括:( )
A. 动态分配内存
B. 节点数不固定
C. 支持双向访问
D. 节点可以不连续存储
解析:正确答案是 C。单链表不支持双向访问,这是双向链表的特点。单链表确实具有动态分配内存、节点数不固定、节点可以不连续存储等特点。
- 单链表的插入和删除操作是否会影响链表中其他节点的位置:( )
A. 会
B. 不会
C. 取决于链表的长度
D. 取决于节点的插入/删除位置
解析:正确答案是 B。单链表的插入和删除操作不会影响其他节点的物理位置,只会改变相关节点的指针。这是链表相对于数组的一个优势。
- 单链表中的表头插入操作所需时间是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
解析:正确答案是 A。表头插入操作只需要调整头指针和新节点的指针,不需要遍历链表,因此时间复杂度是 O(1)。
- 若要判断单链表是否为空表,最有效的办法是检查:( )
A. 数据域是否为空
B. 头指针是否为 NULL
C. 尾指针是否为 NULL
D. 链表长度是否为 0
解析:正确答案是 B。检查头指针是否为 NULL 是判断单链表是否为空的最直接和有效的方法。如果头指针为 NULL,表示链表没有任何节点,即为空表。
- 在单链表中,如何有效地删除链表中的所有节点:( )
A. 遍历链表删除每个节点
B. 将头指针置为 NULL
C. 直接删除头节点
D. 释放链表的内存空间
解析:正确答案是 A。要有效地删除链表中的所有节点,需要遍历链表并逐个删除节点,同时释放每个节点占用的内存。仅将头指针置为 NULL 或删除头节点会导致内存泄漏。
1.2单链表代码操作
- 以下哪组操作能完成在单链表结点
p
之后插入结点s
的效果:( )
A. s->next = p->next; p->next = s;
B. p->next = s; s->next = p->next;
C. s->next = p->next->next; p->next = s;
D. p->next = s; s->next = p->next->next;
- 在单链表中,若要删除结点
p
之后的结点q
,应进行以下哪组操作:( )
A. p->next = q->next; delete q;
B. q->next = p->next; delete q;
C. p->next = q; delete q->next;
D. q = p->next; delete p;
- 在单链表中,将
s
结点插入到头结点head
之后的正确操作是:( )
A. s->next = head->next; head->next = s;
B. head->next = s; s->next = head;
C. s->next = head; head = s;
D. head = s; s->next = head->next;
- 在单链表中,如果要在链表末尾添加一个新节点
s
,以下哪组操作是正确的:( )
A. 遍历到链表最后一个节点p
,然后执行p->next = s; s->next = NULL;
B. head->next = s; s->next = NULL;
C. p->next = s; s->next = p;
D. s->next = p->next; p->next = s;
- 在单链表中删除节点
p
之后的节点q
的正确操作是:( )
A. p->next = q->next; delete q;
B. q->next = p->next; delete p;
C. p->next = p; delete q;
D. q = p->next; delete p;
- 在单链表中,若要在节点
p
前插入节点s
,最简便的方法是:( )
A. 遍历链表找到p
的前驱节点
B. 在p
之后插入节点s
C. 将p
节点的值赋给s
,然后在p
之后插入新的p
D. 直接在p
之前插入节点s
- 在单链表中,如果已知
head
指向链表的头节点,以下哪组操作可以将节点p
插入到链表的表头:( )
A. p->next = head; head = p;
B. head->next = p; p->next = head;
C. head = p; p->next = head;
D. p->next = NULL; head = p;
- 若要在单链表的尾部插入新节点
s
,以下哪项操作是必需的:( )
A. 查找链表的最后一个节点
B. 查找链表的第一个节点
C. 查找链表的中间节点
D. 不需要查找任何节点
- 若在单链表中删除某个节点
q
,必须确保以下哪项操作正确:( )
A. 其前驱节点的 next 指针指向q
的后继节点
B. 其后继节点的 next 指针指向q
的前驱节点
C. 删除后将链表重新排序
D. 不需要特殊处理
- 若单链表中仅给定了头指针
head
,则删除头节点的正确操作是:( )
A. head = head->next; delete head;
B. temp = head; head = head->next; delete temp;
C. head = head->next;
D. temp = head; head = head->next; delete head;
- 在单链表中插入节点
s
后,以下哪项检查操作是正确的:( )
A. 检查s->next
是否指向正确的节点
B. 检查链表是否变为双向链表
C. 检查s->prev
是否指向前驱节点
D. 检查s->next
是否为 NULL
- 在单链表中,删除某个节点的主要难点在于:( )
A. 找到该节点的前驱节点
B. 找到该节点的后继节点
C. 重新连接节点
D. 删除该节点的所有数据
- 在单链表中,删除头节点后,头指针
head
应该指向:( )
A. 下一个节点
B. 当前节点的前驱节点
C. 当前节点
D. 最后一个节点
- 若单链表为空,删除操作的结果是:( )
A. 无需操作,链表仍为空
B. 删除链表的头节点
C. 删除链表的尾节点
D. 删除链表的中间节点
- 若在单链表中执行
p->next = q->next; delete q;
,该操作的含义是:( )
A. 删除节点q
并将p
直接连接到q
的后继节点
B. 删除节点p
并将q
直接连接到p
的前驱节点
C. 删除节点p
并将p
的前驱节点连接到q
D. 删除节点q
并将q
的后继节点连接到p
- 在单链表中删除节点
q
时,为什么需要知道q
的前驱节点:( )
A. 因为需要更新前驱节点的 next 指针
B. 因为需要删除前驱节点
C. 因为需要更新后继节点的 next 指针
D. 因为需要重新分配内存
- 在单链表中插入节点
s
时,以下哪个步骤是正确的:( )
A. 将s->next
指向目标位置的后继节点
B. 将目标位置的前驱节点的 next 指针指向s
C. 将s
的 prev 指针指向前驱节点
D. 将s->next
指向前驱节点
- 单链表中,若要在节点
p
后插入节点s
,应先执行哪一步骤:( )
A. 将s->next
设置为p->next
B. 将p->next
设置为s
C. 删除节点p
D. 删除节点s
- 若单链表的头指针
head
为空,表示链表:( )
A. 为空链表
B. 仅有一个节点
C. 有多个节点
D. 已被删除
- 单链表中,若要在链表中删除所有节点,应执行以下哪项操作:( )
A. 遍历链表,逐一删除每个节点
B. 将头指针设为 NULL
C. 删除最后一个节点
D. 删除第一个节点
1.3单链表代码操作解析
- 以下哪组操作能完成在单链表结点
p
之后插入结点s
的效果:( )
A. s->next = p->next; p->next = s;
B. p->next = s; s->next = p->next;
C. s->next = p->next->next; p->next = s;
D. p->next = s; s->next = p->next->next;
答案:A
解析:在单链表中插入节点时,正确的顺序是先设置新节点的 next 指针,再修改前一个节点的 next 指针。选项 A 正确地先将 s 的 next 指向 p 的下一个节点,然后将 p 的 next 指向 s,完成了插入操作。其他选项要么顺序错误,要么连接关系不正确。
- 在单链表中,若要删除结点
p
之后的结点q
,应进行以下哪组操作:( )
A. p->next = q->next; delete q;
B. q->next = p->next; delete q;
C. p->next = q; delete q->next;
D. q = p->next; delete p;
答案:A
解析:删除节点 q 时,需要先将 p 的 next 指针指向 q 的下一个节点(即 q->next),然后删除 q。选项 A 正确地执行了这两步操作。其他选项要么没有正确地重新连接链表,要么删除了错误的节点。
- 在单链表中,将
s
结点插入到头结点head
之后的正确操作是:( )
A. s->next = head->next; head->next = s;
B. head->next = s; s->next = head;
C. s->next = head; head = s;
D. head = s; s->next = head->next;
答案:A
解析:这个操作本质上与在普通节点后插入新节点相同。正确的做法是先将新节点 s 的 next 指向 head 的下一个节点,然后将 head 的 next 指向 s。选项 A 正确地执行了这两步。其他选项要么会导致链表断开,要么会创建循环链表。
- 在单链表中,如果要在链表末尾添加一个新节点
s
,以下哪组操作是正确的:( )
A. 遍历到链表最后一个节点p
,然后执行p->next = s; s->next = NULL;
B. head->next = s; s->next = NULL;
C. p->next = s; s->next = p;
D. s->next = p->next; p->next = s;
答案:A
解析:要在链表末尾添加节点,需要先遍历到最后一个节点,然后将新节点连接到其后。选项 A 正确地描述了这个过程:找到最后一个节点 p,将 p 的 next 指向新节点 s,并将 s 的 next 设为 NULL(表示它是新的尾节点)。其他选项要么没有考虑到遍历过程,要么连接关系不正确。
- 在单链表中删除节点
p
之后的节点q
的正确操作是:( )
A. p->next = q->next; delete q;
B. q->next = p->next; delete p;
C. p->next = p; delete q;
D. q = p->next; delete p;
答案:A
解析:这个问题与第 2 题相同。删除节点 q 的正确步骤是:先将 p 的 next 指向 q 的下一个节点(q->next),然后删除 q。选项 A 正确地执行了这两步。其他选项要么删除了错误的节点,要么没有正确地重新连接链表。
- 在单链表中,若要在节点
p
前插入节点s
,最简便的方法是:( )
A. 遍历链表找到p
的前驱节点
B. 在p
之后插入节点s
C. 将p
节点的值赋给s
,然后在p
之后插入新的p
D. 直接在p
之前插入节点s
答案:C
解析:在单链表中,直接在某个节点之前插入新节点是困难的,因为我们没有直接访问前驱节点的方法。最简便的方法是选项 C:将 p 的值复制到新节点 s,然后在 p 之后插入 s,最后更新 p 的值为原来要插入的值。这样实际上相当于在 p 之前插入了新节点。其他选项要么需要遍历整个链表,要么无法实现在 p 之前插入的效果。
- 在单链表中,如果已知
head
指向链表的头节点,以下哪组操作可以将节点p
插入到链表的表头:( )
A. p->next = head; head = p;
B. head->next = p; p->next = head;
C. head = p; p->next = head;
D. p->next = NULL; head = p;
答案:A
解析:要将节点插入到链表的表头,正确的步骤是:先将新节点的 next 指向当前的头节点,然后将头指针指向新节点。选项 A 正确地执行了这两步:先设置 p->next = head,然后更新 head = p。其他选项要么会创建循环链表,要么会丢失原有的链表结构。
- 若要在单链表的尾部插入新节点
s
,以下哪项操作是必需的:( )
A. 查找链表的最后一个节点
B. 查找链表的第一个节点
C. 查找链表的中间节点
D. 不需要查找任何节点
答案:A
解析:要在单链表的尾部插入新节点,必须先找到链表的最后一个节点。这是因为单链表只能从头到尾遍历,而且最后一个节点的 next 指针为 NULL。找到最后一个节点后,我们才能将新节点连接到其后。因此,选项 A 是必需的操作。
- 若在单链表中删除某个节点
q
,必须确保以下哪项操作正确:( )
A. 其前驱节点的 next 指针指向q
的后继节点
B. 其后继节点的 next 指针指向q
的前驱节点
C. 删除后将链表重新排序
D. 不需要特殊处理
答案:A
解析:在单链表中删除节点时,关键是要保持链表的连续性。正确的做法是将被删除节点的前驱节点的 next 指针指向被删除节点的后继节点。这就是选项 A 所描述的操作。选项 B 不适用于单链表(这更像是双向链表的操作)。选项 C 和 D 都不能确保正确删除节点并维持链表结构。
- 若单链表中仅给定了头指针
head
,则删除头节点的正确操作是:( )
A. head = head->next; delete head;
B. temp = head; head = head->next; delete temp;
C. head = head->next;
D. temp = head; head = head->next; delete head;
答案:B
解析:删除头节点时,需要先保存当前头节点的指针,然后将头指针移到下一个节点,最后删除原头节点。选项 B 正确地执行了这三步:先用 temp 保存当前头节点,然后更新 head 指向下一个节点,最后删除 temp(原头节点)。选项 A 和 D 会导致访问已删除的内存,选项 C 则会造成内存泄漏。
- 在单链表中插入节点
s
后,以下哪项检查操作是正确的:( )
A. 检查s->next
是否指向正确的节点
B. 检查链表是否变为双向链表
C. 检查s->prev
是否指向前驱节点
D. 检查s->next
是否为 NULL
答案:A
解析:在单链表中插入新节点后,最重要的是确保新节点正确地连接到链表中。选项 A 正确地指出了应该检查 s->next 是否指向正确的节点。选项 B 和 C 不适用于单链表(这些更适合双向链表)。选项 D 只有在 s 被插入到链表末尾时才可能正确。
- 在单链表中,删除某个节点的主要难点在于:( )
A. 找到该节点的前驱节点
B. 找到该节点的后继节点
C. 重新连接节点
D. 删除该节点的所有数据
答案:A
解析:在单链表中删除节点的主要难点是找到要删除节点的前驱节点。这是因为单链表只能从头到尾遍历,而删除操作需要修改前驱节点的 next 指针。找到前驱节点后,重新连接节点(让前驱节点指向被删除节点的后继)就相对简单了。选项 B、C 和 D 相比之下都不是主要难点。
- 在单链表中,删除头节点后,头指针
head
应该指向:( )
A. 下一个节点
B. 当前节点的前驱节点
C. 当前节点
D. 最后一个节点
答案:A
解析:删除头节点后,新的头节点应该是原来的第二个节点,即原头节点的下一个节点。因此,头指针 head 应该更新为指向下一个节点,这就是选项 A 所描述的。选项 B 不适用(单链表没有前驱指针),选项 C 会导致访问已删除的节点,选项 D 则完全改变了链表结构。
- 若单链表为空,删除操作的结果是:( )
A. 无需操作,链表仍为空
B. 删除链表的头节点
C. 删除链表的尾节点
D. 删除链表的中间节点
答案:A
解析:当单链表为空时,它不包含任何节点。因此,对空链表执行删除操作实际上不会改变链表的状态 —— 链表在操作前后都是空的。这就是选项 A 所描述的情况。选项 B、C 和 D 都假设链表中有节点,这与题目中链表为空的条件不符。
- 若在单链表中执行
p->next = q->next; delete q;
,该操作的含义是:( )
A. 删除节点q
并将p
直接连接到q
的后继节点
B. 删除节点p
并将q
直接连接到p
的前驱节点
C. 删除节点p
并将p
的前驱节点连接到q
D. 删除节点q
并将q
的后继节点连接到p
答案:A
解析:这段代码的操作是删除节点 q 并保持链表的连续性。具体来说:
p->next = q->next
将节点 p 的 next 指针指向 q 的后继节点,delete q
然后删除节点 q。
这正是选项 A 所描述的操作:删除节点 q,并将 p 直接连接到 q 的后继节点。其他选项描述的操作与代码不符。
- 在单链表中删除节点
q
时,为什么需要知道q
的前驱节点:( )
A. 因为需要更新前驱节点的 next 指针
B. 因为需要删除前驱节点
C. 因为需要更新后继节点的 next 指针
D. 因为需要重新分配内存
答案:A
解析:在单链表中删除节点 q 时,需要知道 q 的前驱节点是因为我们需要更新前驱节点的 next 指针。这是保持链表连续性的关键步骤。具体来说,我们需要将 q 的前驱节点的 next 指针指向 q 的后继节点,从而在链表中"跳过"节点 q。选项 B、C 和 D 都不是删除操作中需要知道前驱节点的原因。
- 在单链表中插入节点
s
时,以下哪个步骤是正确的:( )
A. 将s->next
指向目标位置的后继节点
B. 将目标位置的前驱节点的 next 指针指向s
C. 将s
的 prev 指针指向前驱节点
D. 将s->next
指向前驱节点
答案:A
解析:在单链表中插入节点时,第一个正确的步骤是将新节点的 next 指针指向插入位置的后继节点。这就是选项 A 所描述的操作。这样做可以确保新节点正确地链接到后面的节点。选项 B 是插入操作的第二步,而不是第一步。选项 C 不适用于单链表(这是双向链表的操作)。选项 D 会导致链表结构错误。
- 单链表中,若要在节点
p
后插入节点s
,应先执行哪一步骤:( )
A. 将s->next
设置为p->next
B. 将p->next
设置为s
C. 删除节点p
D. 删除节点s
答案:A
解析:在节点 p 后插入节点 s 时,正确的第一步是将 s 的 next 指针指向 p 的下一个节点。这就是选项 A 所描述的操作:将 s->next 设置为 p->next。这样做可以确保新节点 s 正确地链接到 p 的后继节点。只有在完成这一步之后,才能将 p 的 next 指针指向 s(这是第二步)。选项 C 和 D 描述的是删除操作,与插入操作无关。
- 若单链表的头指针
head
为空,表示链表:( )
A. 为空链表
B. 仅有一个节点
C. 有多个节点
D. 已被删除
答案:A
解析:在单链表中,头指针 head 为空(即 NULL 或 nullptr)表示这是一个空链表。空链表意味着链表中没有任何节点。这就是选项 A 所描述的情况。如果链表有一个或多个节点(选项 B 和 C),头指针就不会为空,而是会指向第一个节点。选项 D 的说法不准确,因为即使链表被"删除",通常也只是将头指针设为空,这仍然符合选项 A 的描述。
- 单链表中,若要在链表中删除所有节点,应执行以下哪项操作:( )
A. 遍历链表,逐一删除每个节点
B. 将头指针设为 NULL
C. 删除最后一个节点
D. 删除第一个节点
答案:A
解析:要正确地删除单链表中的所有节点,应该遍历整个链表,逐一删除每个节点。这就是选项 A 所描述的操作。这种方法可以确保所有节点占用的内存都被正确释放,避免内存泄漏。选项 B 虽然会使链表变为空链表,但并没有释放节点占用的内存,会导致内存泄漏。选项 C 和 D 只删除了一个节点,不能达到删除所有节点的目的。
2 .1双链表基础知识
- 双链表中的每个节点至少包含以下哪些部分:( )
A. 数据域
B. 前驱指针
C. 后继指针
D. 数据域、前驱指针和后继指针
- 在双链表中,通常使用哪个指针来访问链表的前一个节点:( )
A. next 指针
B. prev 指针
C. head 指针
D. tail 指针
- 在双链表中,如果要访问下一个节点,应使用以下哪个指针:( )
A. next 指针
B. prev 指针
C. head 指针
D. tail 指针
- 双链表的插入操作时间复杂度通常为:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 在双链表中,删除某个节点
p
的时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 在双链表中,查找某个节点的时间复杂度通常是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
- 若在双链表中插入一个新节点
s
,以下哪个步骤是必须的:( )
A. 将s->next
指向当前节点的 next 指针
B. 将当前节点的 prev 指针指向s
C. 将s->prev
指向当前节点的 prev 指针
D. 将s->prev
和s->next
分别指向前驱节点和后继节点
- 在双链表中,如果要删除节点
p
,以下哪个操作是正确的:( )
A. 将p->prev->next
指向p->next
,并将p->next->prev
指向p->prev
B. 直接删除p
,无需其他操作
C. 将p->next
指向p->prev
D. 将p->prev
指向p->next
- 在双链表中,如果要在链表末尾插入一个新节点
s
,以下哪个操作是正确的:( )
A. 将tail->next
指向s
,并将s->prev
指向tail
B. 将tail->prev
指向s
C. 将tail
设为s
D. 将s->next
设为 NULL
- 若要在双链表中插入新节点
s
在节点p
之前,应进行的操作是:( )
A. 将s->next
指向p
,并将s->prev
指向p->prev
B. 将p->prev->next
指向s
,并将p->prev
指向s
C. 将p->next->prev
指向s
D. A 和 B 都正确
- 若要在双链表中删除节点
p
之前的节点q
,以下操作是正确的:( )
A. 将p->prev->prev
指向q
B. 将p->prev->next
指向p
,并将p->prev
指向p->prev->prev
C. 将p->prev->next
指向p->prev
,并删除q
D. 直接删除q
- 双链表相比单链表的优势之一是:( )
A. 支持双向遍历
B. 占用的内存更少
C. 操作复杂度更低
D. 数据访问速度更快
- 在双链表中删除节点
p
后,以下哪项操作是正确的:( )
A. 更新p->prev->next
和p->next->prev
指针
B. 直接删除p
,不需更新指针
C. 更新p->next
和p->prev
指针
D. 将p->next
指针设为 NULL
- 在双链表中,如果要插入节点
s
到头节点head
之前,以下哪组操作是正确的:( )
A.s->next = head; head->prev = s; s->prev = NULL; head = s;
B.s->next = head; s->prev = head->prev; head->prev->next = s; head->prev = s; head = s;
C.s->next = head->prev; s->prev = head; head->prev->next = s; head = s;
D.s->next = head; head->prev = s; head = s;
- 在双链表中,判断链表为空的条件是:( )
A.head == NULL
B.tail == NULL
C.head->next == NULL
D.tail->prev == NULL
- 在双链表中,如果
head
是头指针,tail
是尾指针,如何表示链表为空:( )
A.head == NULL && tail == NULL
B.head == tail
C.head->next == NULL
D.tail->prev == NULL
- 在双链表中,如果要在节点
p
之后插入新节点s
,以下哪组操作是正确的:( )
A.s->next = p->next; s->prev = p; p->next->prev = s; p->next = s;
B.s->prev = p->next; s->next = p->prev; p->prev->next = s; p->next = s;
C.p->next = s; s->prev = p; s->next = p->next->next; p->next->prev = s;
D.p->next = s; s->next = p->prev; s->prev = p; p->next->prev = s;
- 在双链表中,如果要删除尾节点
tail
,以下操作是正确的:( )
A.tail = tail->prev; tail->next = NULL;
B.tail->prev->next = NULL; delete tail;
C.tail = tail->prev; delete tail->next;
D.tail = NULL;
- 若要在双链表的头部插入新节点
s
,并让s
成为新头节点,以下哪项操作是正确的:( )
A.s->next = head; head->prev = s; head = s;
B.head->prev = s; s->next = head; s = head;
C.s->next = head; head = s;
D.s->next = head; head->prev = s;
- 在双链表中,删除链表中的所有节点的最有效方法是:( )
A. 逐个节点删除,并更新前驱和后继指针
B. 仅删除头节点和尾节点
C. 将所有节点的指针设为 NULL
D. 将链表的头指针和尾指针设为 NULL
2.2双链表基础知识解析
- 双链表中的每个节点至少包含以下哪些部分:( )
A. 数据域
B. 前驱指针
C. 后继指针
D. 数据域、前驱指针和后继指针
答案:D
解析:双链表的每个节点必须包含三个部分:数据域(存储节点的实际数据)、前驱指针(指向前一个节点)和后继指针(指向后一个节点)。这三个部分共同构成了双链表节点的基本结构,使得双链表可以双向遍历。
- 在双链表中,通常使用哪个指针来访问链表的前一个节点:( )
A. next 指针
B. prev 指针
C. head 指针
D. tail 指针
答案:B
解析:在双链表中,prev 指针(前驱指针)用于访问链表的前一个节点。这是双链表区别于单链表的关键特征之一,允许我们从当前节点直接访问其前一个节点,而不需要从头遍历链表。
- 在双链表中,如果要访问下一个节点,应使用以下哪个指针:( )
A. next 指针
B. prev 指针
C. head 指针
D. tail 指针
答案:A
解析:在双链表中,next 指针(后继指针)用于访问链表的下一个节点。这与单链表类似,允许我们从当前节点直接访问其后一个节点。
- 双链表的插入操作时间复杂度通常为:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
答案:A
解析:双链表的插入操作时间复杂度通常为 O(1)。这是因为如果我们已知插入位置(即已有指向要插入位置的指针),我们只需要调整几个指针就可以完成插入操作,这些操作的数量是固定的,不依赖于链表的长度。
- 在双链表中,删除某个节点
p
的时间复杂度是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
答案:A
解析:在双链表中,如果已经有指向要删除节点的指针,删除操作的时间复杂度是 O(1)。这是因为我们只需要调整被删除节点的前驱和后继节点的指针,这些操作的数量是固定的,不依赖于链表的长度。
- 在双链表中,查找某个节点的时间复杂度通常是:( )
A. O(1)
B. O(n)
C. O(log n)
D. O(n^2)
答案:B
解析:在双链表中,查找某个特定节点的时间复杂度通常是 O(n)。这是因为在最坏情况下,我们可能需要遍历整个链表才能找到目标节点。虽然双链表支持双向遍历,但这并不能改变查找操作的线性时间复杂度。
- 若在双链表中插入一个新节点
s
,以下哪个步骤是必须的:( )
A. 将s->next
指向当前节点的 next 指针
B. 将当前节点的 prev 指针指向s
C. 将s->prev
指向当前节点的 prev 指针
D. 将s->prev
和s->next
分别指向前驱节点和后继节点
答案:D
解析:在双链表中插入新节点时,必须确保新节点正确地连接到其前驱和后继节点。选项 D 描述了这一必要步骤:新节点的 prev 指针必须指向其前驱节点,next 指针必须指向其后继节点。这确保了新节点在双向链接中的正确位置。
- 在双链表中,如果要删除节点
p
,以下哪个操作是正确的:( )
A. 将p->prev->next
指向p->next
,并将p->next->prev
指向p->prev
B. 直接删除p
,无需其他操作
C. 将p->next
指向p->prev
D. 将p->prev
指向p->next
答案:A
解析:在双链表中删除节点 p 的正确操作是选项 A。这个操作包括两步:
- 将 p 的前驱节点的 next 指针指向 p 的后继节点(
p->prev->next = p->next
) - 将 p 的后继节点的 prev 指针指向 p 的前驱节点(
p->next->prev = p->prev
)
这样可以确保在删除 p 后,链表仍然保持正确的双向连接。
- 在双链表中,如果要在链表末尾插入一个新节点
s
,以下哪个操作是正确的:( )
A. 将tail->next
指向s
,并将s->prev
指向tail
B. 将tail->prev
指向s
C. 将tail
设为s
D. 将s->next
设为 NULL
答案:A
解析:在双链表末尾插入新节点 s 的正确操作是选项 A。这个操作包括两个主要步骤:
- 将当前尾节点的 next 指针指向新节点 s(
tail->next = s
) - 将新节点 s 的 prev 指针指向当前尾节点(
s->prev = tail
)
此外,还需要将 s 的 next 指针设为 NULL,并更新 tail 指针指向 s。这样可以确保新节点正确地成为链表的新尾节点。
- 若要在双链表中插入新节点
s
在节点p
之前,应进行的操作是:( )
A. 将s->next
指向p
,并将s->prev
指向p->prev
B. 将p->prev->next
指向s
,并将p->prev
指向s
C. 将p->next->prev
指向s
D. A 和 B 都正确
答案:D
解析:在双链表中,在节点 p 之前插入新节点 s 需要进行以下操作:
- 设置新节点 s 的指针:
s->next = p
(新节点指向 p)s->prev = p->prev
(新节点的前驱是 p 的前驱)
- 更新 p 的前驱节点的指针:
p->prev->next = s
(p 的前驱节点的后继变为 s)
- 更新 p 的指针:
p->prev = s
(p 的前驱变为 s)
选项 A 和 B 共同描述了这些必要的步骤,因此答案是 D。
- 若要在双链表中删除节点
p
之前的节点q
,以下操作是正确的:( )
A. 将p->prev->prev
指向q
B. 将p->prev->next
指向p
,并将p->prev
指向p->prev->prev
C. 将p->prev->next
指向p->prev
,并删除q
D. 直接删除q
答案:B
解析:要在双链表中删除节点 p 之前的节点 q,正确的操作是选项 B。这个操作包括:
- 将 q 的前驱节点的 next 指针指向 p:
p->prev->next = p
- 将 p 的 prev 指针指向 q 的前驱节点:
p->prev = p->prev->prev
这样可以正确地将 q 从链表中移除,同时保持链表的连续性。最后,还需要删除节点 q 以释放内存。
- 双链表相比单链表的优势之一是:( )
A. 支持双向遍历
B. 占用的内存更少
C. 操作复杂度更低
D. 数据访问速度更快
答案:A
解析:双链表相比单链表的主要优势是支持双向遍历(选项 A)。因为每个节点都有指向前一个和后一个节点的指针,所以可以方便地在两个方向上遍历链表。这使得某些操作(如从尾到头遍历或删除当前节点)变得更加高效。然而,双链表占用更多内存(每个节点多一个指针),大多数操作的复杂度与单链表相同,数据访问速度也没有本质区别。
- 在双链表中删除节点
p
后,以下哪项操作是正确的:( )
A. 更新p->prev->next
和p->next->prev
指针
B. 直接删除p
,不需更新指针
C. 更新p->next
和p->prev
指针
D. 将p->next
指针设为 NULL
答案:A
解析:在双链表中删除节点 p 后,正确的操作是更新 p 的前驱和后继节点的指针(选项 A)。具体来说:
- 将 p 的前驱节点的 next 指针指向 p 的后继节点:
p->prev->next = p->next
- 将 p 的后继节点的 prev 指针指向 p 的前驱节点:
p->next->prev = p->prev
这样可以确保在删除 p 后,链表仍然保持正确的连接。最后,还需要释放 p 占用的内存。
- 在双链表中,如果要插入节点
s
到头节点head
之前,以下哪组操作是正确的:( )
A.s->next = head; head->prev = s; s->prev = NULL; head = s;
B.s->next = head; s->prev = head->prev; head->prev->next = s; head->prev = s; head = s;
C.s->next = head->prev; s->prev = head; head->prev->next = s; head = s;
D.s->next = head; head->prev = s; head = s;
答案:A
解析:在双链表中,将节点 s 插入到头节点 head 之前的正确操作是选项 A。这个操作包括以下步骤:
- 将 s 的 next 指向当前的 head:
s->next = head
- 将当前 head 的 prev 指向 s:
head->prev = s
- 将 s 的 prev 设为 NULL(因为 s 将成为新的头节点):
s->prev = NULL
- 更新 head 指向 s:
head = s
这样可以正确地将 s 插入为新的头节点,同时保持链表的正确结构。
- 在双链表中,判断链表为空的条件是:( )
A.head == NULL
B.tail == NULL
C.head->next == NULL
D.tail->prev == NULL
答案:A
解析:在双链表中,判断链表为空的标准条件是头指针 head 为 NULL(选项 A)。当链表为空时,它不包含任何节点,因此头指针应该是 NULL。尾指针(如果有的话)也应该是 NULL,但通常我们用头指针来判断链表是否为空。选项 C 和 D 不适用,因为如果链表为空,head 和 tail 本身就是 NULL,无法访问它们的 next 或 prev。
- 在双链表中,如果
head
是头指针,tail
是尾指针,如何表示链表为空:( )
A.head == NULL && tail == NULL
B.head == tail
C.head->next == NULL
D.tail->prev == NULL
答案:A
解析:在双链表中,链表为空的正确表示是 head == NULL && tail == NULL
(选项A)。当链表为空时,既没有头节点也没有尾节点,因此头指针和尾指针都应该是NULL。选项B(head == tail
)在链表只有一个节点时也成立,不能准确表示空链表。选项C和D在链表为空时无法执行,因为空链表中没有节点可以访问next或prev。
- 在双链表中,如果要在节点
p
之后插入新节点s
,以下哪组操作是正确的:( )
A.s->next = p->next; s->prev = p; p->next->prev = s; p->next = s;
B.s->prev = p->next; s->next = p->prev; p->prev->next = s; p->next = s;
C.p->next = s; s->prev = p; s->next = p->next->next; p->next->prev = s;
D.p->next = s; s->next = p->prev; s->prev = p; p->next->prev = s;
答案:A
解析:在节点p之后插入新节点s的正确操作顺序是选项A。这个过程包括四个步骤:
s->next = p->next;
新节点s的next指向p的下一个节点s->prev = p;
新节点s的prev指向pp->next->prev = s;
p的下一个节点的prev指向新节点sp->next = s;
p的next指向新节点s
这个顺序确保了链表的连续性和正确性。其他选项要么步骤顺序不正确,要么指针设置错误。
- 在双链表中,如果要删除尾节点
tail
,以下操作是正确的:( )
A.tail = tail->prev; tail->next = NULL;
B.tail->prev->next = NULL; delete tail;
C.tail = tail->prev; delete tail->next;
D.tail = NULL;
答案:C
解析:删除双链表的尾节点的正确操作是选项C。这个过程包括以下步骤:
tail = tail->prev;
将尾指针移动到倒数第二个节点delete tail->next;
删除原尾节点tail->next = NULL;
将新尾节点的next指针设为NULL(这步在选项中没有明确给出,但是应该执行)
选项A没有释放原尾节点的内存。选项B在删除tail后又试图访问它,这是不安全的。选项D只是将尾指针设为NULL,没有正确删除节点和调整链表。
- 若要在双链表的头部插入新节点
s
,并让s
成为新头节点,以下哪项操作是正确的:( )
A.s->next = head; head->prev = s; head = s;
B.head->prev = s; s->next = head; s = head;
C.s->next = head; head = s;
D.s->next = head; head->prev = s;
答案:A
解析:在双链表头部插入新节点s并使其成为新的头节点的正确操作是选项A。这个过程包括三个步骤:
s->next = head;
新节点s的next指向当前的头节点head->prev = s;
当前头节点的prev指向新节点shead = s;
更新头指针指向新节点s
还应该将s->prev设置为NULL,虽然选项中没有明确给出这一步。选项B中s = head
是错误的,因为这样并没有更新头指针。选项C和D都不完整,缺少了一些必要的指针更新。
- 在双链表中,删除链表中的所有节点的最有效方法是:( )
A. 逐个节点删除,并更新前驱和后继指针
B. 仅删除头节点和尾节点
C. 将所有节点的指针设为 NULL
D. 将链表的头指针和尾指针设为 NULL
答案:A
解析:删除双链表中所有节点的最有效方法是选项A,即逐个节点删除并更新指针。这个过程通常如下:
- 从头节点开始,遍历链表
- 对于每个节点,保存其next指针
- 删除当前节点
- 移动到下一个节点(使用保存的next指针)
- 重复步骤2-4直到所有节点被删除
- 最后将头指针和尾指针(如果有)设为NULL
这种方法确保了所有节点都被正确删除,并且内存被适当释放。选项B只删除了两个节点,选项C和D都没有实际删除节点,会导致内存泄漏。
2.3循环链表基础知识
- 在循环单链表的末尾插入新节点的正确代码是:( )
A. newNode->next = head; tail->next = newNode; B. tail->next = newNode; newNode->next = head; C. newNode->next = head; tail = newNode; D. tail->next = newNode; tail = newNode; newNode->next = head;
- 在循环单链表中删除头节点的正确代码是:( )
A. head = head->next; delete tail->next; tail->next = head; B. Node* temp = head; head = head->next; tail->next = head; delete temp; C. head = head->next; tail->next = head; D. Node* temp = head; head = head->next; delete temp;
- 检查循环单链表是否为空的正确代码是:( )
A. return head == nullptr; B. return head->next == head; C. return tail == nullptr; D. return head == tail;
- 在循环单链表中查找特定值的节点的正确代码是:( )
A. while (current != nullptr) { if (current->data == value) return current; current = current->next; } B. do { if (current->data == value) return current; current = current->next; } while (current != head); C. while (current->next != head) { if (current->data == value) return current; current = current->next; } D. for (Node* p = head; p->next != head; p = p->next) { if (p->data == value) return p; }
- 反转循环单链表的正确代码是:( )
A. Node *prev = nullptr, *current = head, *next; do { next = current->next; current->next = prev; prev = current; current = next; } while (current != head); B. Node *prev = tail, *current = head, *next; do { next = current->next; current->next = prev; prev = current; current = next; } while (current != head); C. Node *prev = nullptr, *current = head, *next; while (current != nullptr) { next = current->next; current->next = prev; prev = current; current = next; } D. Node *prev = tail, *current = head, *next; do { next = current->next; current->next = prev; prev = current; current = next; } while (current != head); tail = head; head = prev;
- 在循环单链表中找到中间节点的正确代码是:( )
A. Node *slow = head, *fast = head; while (fast->next != head && fast->next->next != head) { slow = slow->next; fast = fast->next->next; } return slow; B. Node *slow = head, *fast = head; do { slow = slow->next; fast = fast->next->next; } while (fast != head && fast->next != head); return slow; C. Node *slow = head, *fast = head; while (fast != nullptr && fast->next != nullptr) { slow = slow->next; fast = fast->next->next; } return slow; D. Node *slow = head, *fast = head->next; while (fast != head && fast->next != head) { slow = slow->next; fast = fast->next->next; } return slow;
- 检测单链表是否为循环链表的正确代码是:( )
A. Node* current = head; while (current != nullptr) { if (current->next == head) return true; current = current->next; } return false; B. Node *slow = head, *fast = head; while (fast != nullptr && fast->next != nullptr) { slow = slow->next; fast = fast->next->next; if (slow == fast) return true; } return false; C. Node* current = head; do { current = current->next; } while (current != nullptr && current != head); return (current == head); D. Node* current = head; while (current->next != nullptr) { if (current->next == head) return true; current = current->next; } return false;
- 在循环单链表中删除尾节点的正确代码是:( )
A. Node* current = head; while (current->next != tail) current = current->next; current->next = head; delete tail; tail = current; B. Node* current = head; while (current->next->next != head) current = current->next; delete current->next; current->next = head; C. tail = tail->prev; tail->next = head; delete tail->next; D. Node* current = head; do { current = current->next; } while (current->next != tail); delete tail; current->next = head; tail = current;
- 合并两个有序循环单链表的正确代码是:( )
A. Node* tail1 = head1; while (tail1->next != head1) tail1 = tail1->next; tail1->next = head2; Node* tail2 = head2; while (tail2->next != head2) tail2 = tail2->next; tail2->next = head1; B. Node* tail1 = head1->next; Node* tail2 = head2->next; while (tail1->next != head1) tail1 = tail1->next; while (tail2->next != head2) tail2 = tail2->next; tail1->next = head2; tail2->next = head1; C. Node* tail1 = head1; Node* tail2 = head2; while (tail1->next != head1) tail1 = tail1->next; while (tail2->next != head2) tail2 = tail2->next; tail1->next = head2; tail2->next = head1; D. do { if (head1->data <= head2->data) { tail->next = head1; head1 = head1->next; } else { tail->next = head2; head2 = head2->next; } tail = tail->next; } while (head1 != tail1 && head2 != tail2);
- 在循环双链表中插入新节点到当前节点之后的正确代码是:( )
A. newNode->next = current->next; newNode->prev = current; current->next->prev = newNode; current->next = newNode; B. newNode->next = current->next; current->next->prev = newNode; current->next = newNode; newNode->prev = current; C. current->next->prev = newNode; newNode->next = current->next; newNode->prev = current; current->next = newNode; D. newNode->prev = current; current->next = newNode; newNode->next = current->next; current->next->prev = newNode;
- 在循环单链表中找到中间节点的正确代码是:( )
A. Node *slow = head, *fast = head; while (fast->next != head && fast->next->next != head) { slow = slow->next; fast = fast->next->next; } return slow; B. Node *slow = head, *fast = head; do { slow = slow->next; fast = fast->next->next; } while (fast != head && fast->next != head); return slow; C. Node *slow = head, *fast = head; while (fast != nullptr && fast->next != nullptr) { slow = slow->next; fast = fast->next->next; } return slow; D. Node *slow = head, *fast = head->next; while (fast != head && fast->next != head) { slow = slow->next; fast = fast->next->next; } return slow;
- 检测单链表是否为循环链表的正确代码是:( )
A. Node* current = head; while (current != nullptr) { if (current->next == head) return true; current = current->next; } return false; B. Node *slow = head, *fast = head; while (fast != nullptr && fast->next != nullptr) { slow = slow->next; fast = fast->next->next; if (slow == fast) return true; } return false; C. Node* current = head; do { current = current->next; } while (current != nullptr && current != head); return (current == head); D. Node* current = head; while (current->next != nullptr) { if (current->next == head) return true; current = current->next; } return false;
- 在循环单链表中删除尾节点的正确代码是:( )
A. Node* current = head; while (current->next != tail) current = current->next; current->next = head; delete tail; tail = current; B. Node* current = head; while (current->next->next != head) current = current->next; delete current->next; current->next = head; C. tail = tail->prev; tail->next = head; delete tail->next; D. Node* current = head; do { current = current->next; } while (current->next != tail); delete tail; current->next = head; tail = current;
- 合并两个有序循环单链表的正确代码是:( )
A. Node* tail1 = head1; while (tail1->next != head1) tail1 = tail1->next; tail1->next = head2; Node* tail2 = head2; while (tail2->next != head2) tail2 = tail2->next; tail2->next = head1; B. Node* tail1 = head1->next; Node* tail2 = head2->next; while (tail1->next != head1) tail1 = tail1->next; while (tail2->next != head2) tail2 = tail2->next; tail1->next = head2; tail2->next = head1; C. Node* tail1 = head1; Node* tail2 = head2; while (tail1->next != head1) tail1 = tail1->next; while (tail2->next != head2) tail2 = tail2->next; tail1->next = head2; tail2->next = head1; D. do { if (head1->data <= head2->data) { tail->next = head1; head1 = head1->next; } else { tail->next = head2; head2 = head2->next; } tail = tail->next; } while (head1 != tail1 && head2 != tail2);
- 在循环双链表中插入新节点到当前节点之后的正确代码是:( )
A. newNode->next = current->next; newNode->prev = current; current->next->prev = newNode; current->next = newNode; B. newNode->next = current->next; current->next->prev = newNode; current->next = newNode; newNode->prev = current; C. current->next->prev = newNode; newNode->next = current->next; newNode->prev = current; current->next = newNode; D. newNode->prev = current; current->next = newNode; newNode->next = current->next; current->next->prev = newNode;
- 在循环单链表中实现节点的交换(交换相邻的两个节点)的正确代码是:( )
A. Node* temp = current->next; current->next = temp->next; temp->next = current; prev->next = temp; B. Node* temp = current->next; current->next = temp->next; temp->next = current; prev->next = temp; if (head == current) head = temp; C. Node* temp = current->next; current->next = temp->next; temp->next = current; prev->next = temp; if (tail == temp) tail = current; D. Node* temp = current->next; current->next = temp->next; temp->next = current; prev->next = temp; if (head == current) head = temp; if (tail == temp) tail = current;
- 在循环单链表中计算链表长度的正确代码是:( )
A. int count = 0; Node* current = head; while (current != nullptr) { count++; current = current->next; } return count; B. int count = 1; Node* current = head->next; while (current != head) { count++; current = current->next; } return count; C. int count = 0; Node* current = head; do { count++; current = current->next; } while (current != head); return count; D. int count = 0; for (Node* p = head; p != nullptr; p = p->next) count++; return count;
- 在循环双链表中删除当前节点的正确代码是:( )
A. current->prev->next = current->next; current->next->prev = current->prev; delete current; B. Node* temp = current; current->prev->next = current->next; current->next->prev = current->prev; delete temp; C. current->next->prev = current->prev; current->prev->next = current->next; if (current == head) head = current->next; delete current; D. Node* temp = current; temp->prev->next = temp->next; temp->next->prev = temp->prev; if (temp == head) head = temp->next; delete temp;
- 将两个循环单链表连接成一个的正确代码是:( )
A. Node* tail1 = head1; while (tail1->next != head1) tail1 = tail1->next; tail1->next = head2; Node* tail2 = head2; while (tail2->next != head2) tail2 = tail2->next; tail2->next = head1; B. Node* tail1 = head1->next; while (tail1->next != head1) tail1 = tail1->next; Node* tail2 = head2->next; while (tail2->next != head2) tail2 = tail2->next; tail1->next = head2; tail2->next = head1; C. Node* tail1 = head1; while (tail1->next != head1) tail1 = tail1->next; Node* tail2 = head2; while (tail2->next != head2) tail2 = tail2->next; tail1->next = head2; tail2->next = head1; D. Node* tail1 = head1; do { tail1 = tail1->next; } while (tail1->next != head1); Node* tail2 = head2; do { tail2 = tail2->next; } while (tail2->next != head2); tail1->next = head2; tail2->next = head1;
- 在循环单链表中实现节点的倒序排列的正确代码是:( )
A. Node *prev = nullptr, *current = head, *next; do { next = current->next; current->next = prev; prev = current; current = next; } while (current != head); head = prev; B. Node *prev = tail, *current = head, *next; do { next = current->next; current->next = prev; prev = current; current = next; } while (current != head); head = prev; C. Node *prev = nullptr, *current = head, *next; while (current != nullptr) { next = current->next; current->next = prev; prev = current; current = next; } head = prev; D. Node *prev = tail, *current = head, *next; do { next = current->next; current->next = prev; prev = current; current = next; } while (current != head); tail = head; head = prev;