当前位置:首页 » 编程语言 » c语言单链表逆置

c语言单链表逆置

发布时间: 2023-07-25 20:23:11

❶ 写一c语言算法,实现对单链表就地逆置。

void inverse(LinkList &L)
{
LinkList h,p,q;
q=L;
p=h=L->next; //把q指向旧链表头,p,h指向第二个节点
while(p!=NULL) //倒置,把旧链表后一个节点的next指向前一个节点
{
h->next=q;
q=q->next;
p=p->next;
h=p;
}
L->next=NULL; //旧链表的头变成了新链表的尾,所以next为NULL
L=h; //把L指向新链表的头
}

❷ 下面是用c语言编写的对不带头结点的单链表进行就地逆置的算法,求大神详细解释

voidreverse(linklist&L)
{
linklistp=NULL,q=L;
while(q!=NULL){
L=q->next;//保留下一个节点
q->next=p;
p=q;
q=L;//移动到下一个节点
}
L=p;//指向逆置后的头节点
}

❸ 用c语言实现单链表的逆置,能将此程序详细的解释一下吗

算法的核心就是reverse函数,其它的都是辅助建立链表和输出链表的。
从数据结构的定义来看这是一个带头节点的链表。要弄的十分明白你要耐心点画图看看。我简单的说下思路:
【head是指向头结点的】
p=head; //p最开始指向头结点
s=p->next; //s最开始指向第一个节点
while(s->next!=NULL)//只要没有到最后一个元素就继续。最后一个元素的next肯定为NULL
{ //进入核心了楼主
t=s->next; //用t指向s后面的那个元素
s->next=p; //把s指向她前面那个,这个时候就实现了逆向了。而且是就地逆向。元素都没有动的
p=s; //然后p向后移动s
s=t; //s向后移动到p
这样到下一轮的时候又可以讲下下个再指向刚才那个下一个。一次内推
}
s->next=p; //当最后一个的时候,还是要指向她的前一个。
head->next->next=NULL;//头指针的下一个是指向原来的第一个。逆向后肯定是最后的那个了。所以最后的一个的next=NULL就明了了。
head->next=s;//s是逆序前的最后一个,逆序后是第一个,所以用头指向他

画个图好好体会下,楼主!

热点内容
服务器1u能连接几台电脑 发布:2025-02-07 18:50:02 浏览:152
立人编译 发布:2025-02-07 18:48:32 浏览:763
日产途达四驱的有哪些配置 发布:2025-02-07 18:42:02 浏览:831
服务器搭建镜像站 发布:2025-02-07 18:41:55 浏览:376
游戏上云成标配云服务器该怎么选 发布:2025-02-07 18:26:13 浏览:141
哪个安卓手机自带系统没有广告 发布:2025-02-07 18:22:36 浏览:724
电脑开机后一直在配置更新怎么进入系统 发布:2025-02-07 18:17:43 浏览:12
新浪上传视频在哪 发布:2025-02-07 18:17:38 浏览:558
外汇点差算法 发布:2025-02-07 18:16:41 浏览:81
我的世界各种服务器核心的区别 发布:2025-02-07 18:15:52 浏览:678