请教关于尾插法建立单链表的算法

LinkListCreatListR1(void){//用尾插法建立带头结点的单链表charch;LinkListhead=(ListNode*)malloc(sizeo... LinkList CreatListR1(void)
{//用尾插法建立带头结点的单链表
char ch;
LinkList head=(ListNode *)malloc(sizeof(ListNode));//生成头结点
ListNode *s,*r; //工作指针
r=head; // 尾指针初值也指向头结点
while((ch=getchar())!='\n'){
s=(ListNode *)malloc(sizeof(ListNode));//生成新结点
s->data=ch; //将读入的数据放入新结点的数据域中
r->next=s;
r=s;
}
r->next=NULL;//终端结点的指针域置空,或空表的头结点指针域置空
return head;
}

r->next=s;r=s; 关键的这两句不懂,指针r如何工作的,还有链表间的链接我始终没想明白。
展开
 我来答
小媛9OF
2019-10-21 · TA获得超过1.1万个赞
知道答主
回答量:193
采纳率:0%
帮助的人:4.9万
展开全部

tailing是通过在列表尾部逐个插入新节点来创建列表。与前面的插值一样,每次应用新节点时,都会读入相应的数据元素值。不同之处在于,为了将新节点插入表的尾部,需要添加尾部指针r来指向链表的尾部。

[算法步骤]

创建一个只有头节点的空链表。

②尾部指针R的初始化,指向头部节点。

③根据链表创建中包含的元素n的个数,进行n个循环的以下操作:

生成新节点*p;

●将输入元素值赋给新节点*p的数据字段;

●在尾节点*R后插入新节点*P;

●尾部指针R指向新尾部节点*PS

如图所示,线性表(A、B、C、D、E)后插值的创建过程与线性表相同。

【算法描述】

void Createlist_R(Linklist &L, int n)    //正位序输入n个元素的值,建立带表头结点的单链表L个人

{

L=new LNode;     //先建立一个带头结点的空链表L->next=NULL;   //尾指针指向头结点r=L;

for(i=0;i<n:++i)  //生成新

{

p=newLNode;  //输入元素值赋给新结点p的数据域cin>>p->data;   //将新*p插入尾结点*r之后p->next=NULL;r->next=p;

r=p;    //r指向新的尾结点*p

}

}

算法时间复杂度为O(n)。

扩展资料

尾部插入方法从空表开始,重复读取数据,生成新节点,将读取的数据存储在新节点的数据字段中,然后将新节点插入到当前链表的尾部,直到读取标记结束。从空表开始,重复读取数据,生成新节点,将读取的数据存储在新节点的数据字段中,然后将新节点插入到当前链表的末尾,直到读取标志结束。

参考资料来源:

百度百科-尾插法

Sievers分析仪
2025-01-06 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准... 点击进入详情页
本回答由Sievers分析仪提供
乱七八糟lD4YW
2019-07-14 · TA获得超过841个赞
知道答主
回答量:5
采纳率:100%
帮助的人:2.7万
展开全部

尾插法是通过将新结点逐个插入到链表的尾部来创建链表。同前插法一样,每次申请一个新
结点,读入相应的数据元素值。不同的是,为了使新结点能够插入到表尾,需要增加一个尾指针
r指向链表的尾结点。


【算法步骤】


①创建一个只有头结点的空链表。


②尾指针r初始化,指向头结点。


③根据创建链表包括的元素个数n,循环n次执行以下操作:


●生成一个新结点*p;


●输入元素值赋给新结点*p的数据域;


●将新结点*p插入到尾结点*r之后;


●尾指针r指向新的尾结点*ps


如图所示为线性表(a,b,c,d,e)后插法的创建过程,读入数据的顺序和线性表中的逻辑顺
序是相同的。

【算法描述】


void Createlist_R(Linklist &L, int n)    //正位序输入n个元素的值,建立带表头结点的单链表L个人

{


L=new LNode;     //先建立一个带头结点的空链表

L->next=NULL;   //尾指针指向头结点

r=L;


for(i=0;i<n:++i)    //生成新结点


{


p=new LNode;    //输入元素值赋给新结点p的数据域

cin>>p->data;     //将新结点*p插入尾结点*r之后

p->next=NULL; r->next=p;


r=p;    //r指向新的尾结点*p

}

}

算法时间复杂度为O(n)。

扩展资料:

尾插法是从一个空表开始,重复读入数据,生成新结点,将读入数据存放在新结点的数据域中,然后将新结点插入到当前链表的表尾上,直到读入结束标志为止。

从一个空表开始,重复读入数据,生成新结点,将读入数据存放在新结点的数据域中,然后将新结点插入到当前链表的表尾上,直到读入结束标志为止。

参考资料来源:百度百科-尾插法


本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lessconfident
推荐于2017-11-23 · TA获得超过116个赞
知道答主
回答量:32
采纳率:0%
帮助的人:37万
展开全部
尾插法是向链表尾部逐渐插入结点的,像算法中描述的一样,然后r先指向头指针,s是要逐个插入的结点的指针,r->next=s这句是说把s插入头指针之后,成为第一个结点,意思就是说把s结点接入到链表之中了,然后接着r=s这句是让r指针指向刚刚插入的那一结点,在这个节点之后进行进一步的插入,算法还是r->next=s,逐个逐个往尾部插入结点,直到最后一个结点的指针域为空r->next=NULL跳出循环。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式