网友您好, 请在下方输入框内输入要搜索的题目:

题目内容 (请给出正确答案)

完成在双循环链表结点p之后插入s的操作为: The operation to insert s after the doubly circular linked list’s node p is: (There are more than one answers.)

A.p->next->prev=s; s->prev=p; s->next=p->next; p->next=s;

B.p->next->prev=s; p->next=s; s->prev=p; s->next=p->next;

C.s->prev=p; s->next=p->next; p->next=s; p->next->prev=s;

D.s->next=p->next; p->next->prev=s; s->prev=p; p->next=s;


参考答案和解析
BC
更多 “完成在双循环链表结点p之后插入s的操作为: The operation to insert s after the doubly circular linked list’s node p is: (There are more than one answers.)A.p->next->prev=s; s->prev=p; s->next=p->next; p->next=s;B.p->next->prev=s; p->next=s; s->prev=p; s->next=p->next;C.s->prev=p; s->next=p->next; p->next=s; p->next->prev=s;D.s->next=p->next; p->next->prev=s; s->prev=p; p->next=s;” 相关考题
考题 在一个单链表中p所指结点(p所指不是最后结点)之后插入一个由指针s所指结点,应执行s->next=_______;和p->next=________的操作。

考题 在一个单向链表中p所指结点之后插入一个s所指向的结点时,应执行s->next=p->next;和 的操作。

考题 在一个单链表中p所指结点之后插入一个s所指的结点时,可执行( )。 A.p=sànextB.pànext=sànext;C.sànext=pànext; pànext=s;D.pànext= s; sànext= pànext

考题 在单链表指针为p的结点之后插入指针为s的结点,正确的操作是()。A.p->next=s;s->next=p->next;B.s->next=p->next;p->next=s;C.p->next=s;p->next=s->next;D.p->next=s->next;p->next=s;

考题 在一个单链表中p所指结点之后插入一个s所指的结点时,可执行()。 A.p=s->nextB.p->next=s;s->next=p->nextC.p->next=s->next;D.s->next=p->next;p->next=s;

考题 线性链表中结点的结构为(data,next)。已知指针p所指结点不是尾结点,若在*p之后插入结点*s,则应执行下列()操作。A.s->next=p;p->next=s;B.s->next=p->next;p->next=s;C.s->next=p->next;p=s;D.p->next=s;s->next=p;

考题 在一个单链表中,若p所指结点不是最后结点,在p所指结点之后插入s所指结点,则应执行(32)操作。A.s->link=p;p->link=s;B.s->link=p->link:p->link=s:C.S->link=p->link; p=s:D.p->link=s:s->link=p:

考题 在循环双链表的p结点之后插入s结点的操作是______。A.p→next=s;p→next→prior=s;s→prior=p;s→next=p→next;B.s→!next=p;s→next=p→next;p→next=s;p→next→prior=s;C.p→next=s;s→prior=p;p→next→prior=s;s→next=p→next;D.s→prior=p;s→next=p→next;p→next→prior=s;p→next=s;

考题 在一个单链表中,q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行(29)。A.s→link=p→link;p→link=s;B.p→link=s;s→link=q;C.p→link=s→link;s→link=p;D.q→link=s;s→link=p;

考题 设单链表中结点的结构为已知指针p所指结点不是尾结点,若在*p之后插入结点*s,则应执行下列哪一个操作______。A.s->link=p;p->link=s;B.s->link=p->link;p->link=s;C.s->link=p->link;p=s;D.p->link=s;s->link=p;

考题 在一个单链表中,若q结点是p结点的前驱结点,在q与p之间插入结点s,则执行( )。A.s→link=p→link; p→link=sB.p→link=s; s→link=qC.p→link=s→link; s→link=pD.q→link=s; s→link=p

考题 以下程序的功能是:建立一个带有头结点的单向链表,并将存储在数组中的字符依次转存到链表的各个结点中,请填空。 #include <stdlib.h> stuct node { char data; struet node * next; }; stntct node * CreatList(char * s) { struet node *h,*p,*q; h = (struct node * ) malloc(sizeof(struct node) ); p=q=h; while( * s! ='\0') { p = (struct node *) malloc ( sizeof(struct node) ); p - > data = ( ) q- >next=p; q=p; a++; p- > next ='\0'; return h; } main( ) { char str[ ]= "link list"; struet node * head; head = CreatList(str);A.*sB.sC.*s++D.(*s)++

考题 阅读以下说明和C函数,填补代码中的空缺,将解答填入答题纸的对应栏内。 [说明] 函数ReverseList(LinkList headptr)的功能是将含有头结点的单链表就地逆置。处理思路是将链表中的指针逆转,即将原链表看成由两部分组成:已经完成逆置的部分和未完成逆置的部分,令s指向未逆置部分的第一个结点,并将该结点插入已完成部分的表头(头结点之后),直到全部结点的指针域都修改完成为止。 例如,某单链表如图1所示,逆置过程中指针s的变化情况如图2所示。 链表结点类型定义如下: typedef struct Node{ int data; Struct Node *next; }Node,*LinkList; [C函数] void ReverseList(LinkList headptr) { //含头结点的单链表就地逆置,headptr为头指针 LinkList p,s; if(______) return; //空链表(仅有头结点)时无需处理 P=______; //令P指向第一个元素结点 if(!P->next) return; //链表中仅有一个元素结点时无需处理 s=p->next; //s指向第二个元素结点 ______ =NULL; //设置第一个元素结点的指针域为空 while(s){ p=s; //令p指向未处理链表的第一个结点 s= ______; p->next=headptr->next; //将p所指结点插入已完成部分的表头 headptr->next= ______; } }

考题 设指针q指向单链表中结点A,指针p指向单链表中结点A的后继结点B,指针s指向被插入的结点X,则在结点A和结点B插入结点X的操作序列为()。A.p->next=s;s->next=q; B.q->next=s;s->next=p; C.p->next=s->next;s->next=p; D.s->next=p->next;p->next=-s;

考题 在单链表指针为P的结点之后插入指针为s的结点,正确的操作是()。

考题 在一个单链表中p所指结点之后插入一个s所指的结点时,可执行()。Ap=s-nextBp-next=s;s-next=p-nextCp-next=s-next;Ds-next=p-next;p-next=s;

考题 在一个单向链表中,在p所指结点之后插入一个s所指的结点时,可执行s-next=p-next;和()A、p=sB、p-next=s-nextC、p=s-nextD、p-next=s

考题 已知单链表上一结点的指针为p,则在该结点之后插入新结点*s的正确操作语句为()A、 p->next=s; s->next=p-next;B、 s->next=p->next; p->next=s;C、 p->next=s; p->next=s->next;D、 p->next=s->next; p->next=s;

考题 在双向循环链表中,在p所指的结点之后插入s指针所指的结点,其操作是S-next=p-next;()=s;s-prior=();p-next=s;

考题 在一个单向链表中,在p所指结点之后插入一个s所指的结点时,可执行();和p-next=s;。A、p=s;B、p-next=s-next;C、p=s-next;D、s-next=p-next;

考题 在单链表中,要将s所指结点插入到p所指结点之后,其语句应为()。A、s->next=p+1; p->next=s;B、(*p).next=s; (*s).next=(*p).next;C、s-next=p->next; p->next=s->next;D、s-next=p->next; p->next=s;

考题 在一个单链表中p所指结点之后插入一个s所指的结点时,可执行()。A、p=s-nextB、p-next=s;s-next=p-nextC、p-next=s-next;D、s-next=p-next;p-next=s;

考题 在一个单链表中p所指结点之后插入一个s所指结点时,应执行()和p-next=s;的操作。

考题 在一个单向链表中p所指结点之后插入一个s所指的新结点,应执行s-next=p-next;和()操作。

考题 填空题在双向循环链表中,在p所指的结点之后插入s指针所指的结点,其操作是S-next=p-next;()=s;s-prior=();p-next=s;

考题 填空题设线性链表的存储结构如下: struct node {ELEMTP data; /*数据域*/ struct node *next; /*指针域*/ } 试完成下列在链表中值为x的结点前插入一个值为y的新结点。如果x值不存在,则把新结点插在表尾的算法。 void inserty(struct node *head,ELEMTP x,ELEMTP y) {s=(struct node *)malloc(sizeof(struct node)); (); if(){s-nexr=head;head=s;} else { q=head;p=q-next; while(p-dqta!=xp-next!=NULL){q=p;()} if(p-data= = x){q-next=s;s-next=p;} else{p-next=s;s-next=NULL;} } }

考题 单选题已知单链表上一结点的指针为p,则在该结点之后插入新结点*s的正确操作语句为()A  p->next=s; s->next=p-next;B  s->next=p->next; p->next=s;C  p->next=s; p->next=s->next;D  p->next=s->next; p->next=s;

考题 单选题在一个单向链表中,在p所指结点之后插入一个s所指的结点时,可执行();和p-next=s;。A p=s;B p-next=s-next;C p=s-next;D s-next=p-next;