c语言单链表就地逆置,c语言单向链表逆序思路

本文目录一览:

写一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语言实现单链表的逆置?

扣着的是头节点(头子)

车是首节点(首子)

马是次节点(次子)

牙签细的是指针指向,香头发黑的是指向,铁头细的是指向。

根据步骤写程序的伪算法(3步4循环,7张图片搞定),如下:

以下是while循环(条件:香头指向不为空)

第一个循环把马弄到车前面,

第二个循环把相弄到马前面

第三个循环把士弄到相前面

……..

直到香指向为空后停止循环。

代码如下:只需要一个首结点pHead,就能把链表找到,并倒置。具体代码如下

p香=pHead-pNext;

p铁=p香-pNext;

p香-pNext=NULL;

P香=p铁

while(p香 !=NULL)

{

   p铁=p香-pNext;

   p香-pNext=pHead-pNext;

   pHead-pNext=p香;

   p香=p铁;

}

对照伪算法(三步四循环),和上面的代码是一一对应的:

第一步:香头指向首子,铁头指向次子

第二步:删掉首子指向次子(铁头所指向的那个子)的牙签

第三步:香头跟着铁头

以下循环条件:(条件:香头指向不为空)

{

  循环1:铁头移动到香头的下一个指向

  循环2:香头的下一个指向首子

  循环3:头子的下一个跟着香头

  循环4:香头跟着铁头

}

自己用道具操作几遍,然后把流程背会,以后自己根据流程写代码即可。

单链表就地逆置有几种方法

单链表就地逆置的两种(递归与普通循环)

1.用递归算法,对于不带头结点的单链表(a1,a2,a3,a4,a5,a6)逆置后的结果为(a6,a5,a4,a3,a2,a1)

考虑递归算法,若只有一个结点,则直接返回,若存在两个结点(a1,a2)则需要做的操作有:a2-next=a1;a1-next=NULL;return a2;

a2即新的头结点,若有三个结点,则应先将子链(a2,a3)先逆置且返回该子链的新的头结点,然后把子链(a2,a3)当作一个复合结点a2′,

组成新的二元组(a1,a2’)然后就可以执行前面相同的操作:a2′-next=a1;a1-next=NULL;return a3′;即可,多个以上的结点可同理得到,

Node *Reverse(Node *head)

{

Node *p=head;

if(p==NULL)

return NULL; //若是空链表,返回空

Node *q=p-next;

if(q==NULL)

return p; //若只有一个结点,直接返回

else

head=Reverse(q);//记录子序列的新的头结点

q-next=p; //当前结点与已经逆置的子序列看成是前后的两个结点p,q,作相应的逆置操作

p-next=NULL;

return head; //返回新的子序列的头结点

}

2.用普通算法循环逆置(头插法重新建立带头结点的新链表)

Node *Reverse(Node *head)

{

Node *p=head-next;

if(p)//若链表不为空,则逆置,否则,空操作

{

 Node *q=p-next;

head-next=NULL;//头结点分离

while(p)

{

p-next=head-next; //头插法建立链表

head-next=p;

if(q) //操作空指针的时候一定要非常注意,很容易出错

{

 p=q;

 q=p-next;

}

else

 break;

}

}

return head;

}

c语言用堆栈实现单链表的就地逆置

#define DATATYPE int

struct Node{

DATATYPE data;

Node * next;

};

Node * reverse(Node * list){

//无头节点;

Node * pcur,* pnext,* ppre;

ppre=NULL;

pcur=list;

while(pcur!=NULL){//将链表pcur用头插法插入到一个空链表ppre中则实现了逆置

pnext=pcur-next;

pcur-next=ppre;

ppre=pcur;

pcur=pnext;

}

return ppre;//新的链表指针

}

用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是逆序前的最后一个,逆序后是第一个,所以用头指向他

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

原创文章,作者:CCBC,如若转载,请注明出处:https://www.506064.com/n/149818.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
CCBCCCBC
上一篇 2024-11-05 16:54
下一篇 2024-11-05 16:54

相关推荐

  • 利用Python实现两个链表合并为一个有序链表

    对于开发工程师来说,实现两个链表合并为一个有序链表是必须掌握的技能之一。Python语言在链表处理上非常便利,本文将从多个方面详细阐述如何利用Python实现两个链表合并为一个有序…

    编程 2025-04-29
  • AES加密解密算法的C语言实现

    AES(Advanced Encryption Standard)是一种对称加密算法,可用于对数据进行加密和解密。在本篇文章中,我们将介绍C语言中如何实现AES算法,并对实现过程进…

    编程 2025-04-29
  • 学习Python对学习C语言有帮助吗?

    Python和C语言是两种非常受欢迎的编程语言,在程序开发中都扮演着非常重要的角色。那么,学习Python对学习C语言有帮助吗?答案是肯定的。在本文中,我们将从多个角度探讨Pyth…

    编程 2025-04-29
  • Python被称为胶水语言

    Python作为一种跨平台的解释性高级语言,最大的特点是被称为”胶水语言”。 一、简单易学 Python的语法简单易学,更加人性化,这使得它成为了初学者的入…

    编程 2025-04-29
  • OpenJudge答案1.6的C语言实现

    本文将从多个方面详细阐述OpenJudge答案1.6在C语言中的实现方法,帮助初学者更好地学习和理解。 一、需求概述 OpenJudge答案1.6的要求是,输入两个整数a和b,输出…

    编程 2025-04-29
  • Python按位运算符和C语言

    本文将从多个方面详细阐述Python按位运算符和C语言的相关内容,并给出相应的代码示例。 一、概述 Python是一种动态的、面向对象的编程语言,其按位运算符是用于按位操作的运算符…

    编程 2025-04-29
  • Python编程实现列表元素逆序存放

    本文将从以下几个方面对Python编程实现列表元素逆序存放做详细阐述: 一、实现思路 一般来说,使用Python将列表元素逆序存放可以通过以下几个步骤实现: 1. 定义一个列表 2…

    编程 2025-04-29
  • 枚举法例题及解题思路

    本文将从例题和解题思路两个方面阐述枚举法,帮助读者更好地理解和掌握该算法。 一、基本概念 枚举法,英文名为Brute Force,也叫暴力枚举法,是一种计算机算法,它通过穷举所有可…

    编程 2025-04-29
  • Python语言由荷兰人为中心的全能编程开发工程师

    Python语言是一种高级语言,很多编程开发工程师都喜欢使用Python语言进行开发。Python语言的创始人是荷兰人Guido van Rossum,他在1989年圣诞节期间开始…

    编程 2025-04-28
  • Python语言设计基础第2版PDF

    Python语言设计基础第2版PDF是一本介绍Python编程语言的经典教材。本篇文章将从多个方面对该教材进行详细的阐述和介绍。 一、基础知识 本教材中介绍了Python编程语言的…

    编程 2025-04-28

发表回复

登录后才能评论