【单链表】尾插法建立,头插法就地逆置

【单链表】尾插法建立,头插法就地逆置_第1张图片

 

题目:1.请用尾插法建立一个带头结点的单链表,并用头插法完成单链表的就地逆置,输出单链表中的数据,验证程序是否正确。

    看到刚入门单链表的同学在为这些头插法,尾插法迷惑时,我愿意来讲解一下


总体代码:

#include
#include
typedef int datatype;

typedef struct node{
	  
	  datatype num;
	  struct node *next; 	
}Node, * LinkList; 


//函数
void LinkInitialize(LinkList head);			//用于链表初始化
void LinkBuildRear(LinkList head);			//尾插法建立单链表
void LinkPrint(LinkList head);  			//用于链表输出
void LinkReverse(LinkList head);			//就地逆置(迭代法) 
										

int main()
{
	
	Node node1;
	LinkList p;
	p = &node1;
	//结点指针,用于传入函数改变链表内容 
	LinkInitialize(p);				//结点的初始化 
	LinkBuildRear(p);               //链表的尾插法建立 
	printf("打印原链表:\n");
	LinkPrint(p);
	LinkReverse(p);  				//链表的逆置 
	printf("打印逆置后链表:\n");
	LinkPrint(p);
	
	return 0;
}


/*用于链表初始化*/ 
void LinkInitialize(LinkList head)  //先动态分配内存,再进行结点的指针域赋初值 
{
     head = (LinkList)malloc(sizeof(Node));
     head->next = NULL;
} 


/*尾插法建立单链表*/ 

//先定义结点指针 rear , p ;分别用来指向尾结点,新结点;
//接着新结点中存入数据,让新结点成为 rear 的后继结点
//然后rear指向尾结点
//最后新结点创建结束,即输入数据结束;将 rear 的指针域置为 NULL 
void LinkBuildRear(LinkList head)	
{
	LinkList  rear = head , p;
	datatype num1;
	printf("请输入若干个datatype型数据,以-1为结束:\n");
	while(scanf("%d",&num1),num1 != -1)
	{
		p = (LinkList)malloc(sizeof(Node)); //开辟新结点并输入数据 
		p->num = num1;
		
		rear->next = p;			//让新结点作为rear的后继结点 
		rear = p;      			//让rear总是指向尾结点 	
	}
	  rear->next = NULL;	//数据输入结束,即新结点开辟结束 	
}			


/*用于链表输出*/
//先定义一个结点指针,用于指向首元结点
//接着循环遍历输出每个结点的数据域中的数据
//最后为了输出后看起来清晰,记得换行 
void LinkPrint(LinkList head)
{
	LinkList p = head->next;
	
	while(p != NULL)  //循环遍历,直至指向尾结点的后继结点(NULL) 
	{
		printf("%d ",p->num);
		p = p->next; 	
	}
	printf("\n");
}



/*就地逆置(头插法)*/	
//首先定义两个结点指针 p ,q;分别指向首元结点和次首元结点(p用来遍历,q用来头插) 
//接着先让头结点的指针域置为 NULL;
// q先去找 p 所指的结点,让 p 后移遍历链表;
//然后让 q 指向的结点进行头插		
void LinkReverse(LinkList head)
{
	LinkList p , q;
	p = head->next;
	head->next = NULL; 
	
	while(p != NULL)
	{
	   q = p; 
	   p = p->next; 			//指针p用来遍历链表中的结点 
	   
	   q->next =head->next;		//q进行头插 (核心代码) 
	   head->next = q;	
	}
}		 


对于刚接触单链表的同学,可能这些代码会有两个不懂的地方:

1.尾插法建立带头结点的单链表

2.头插法进行就地逆置

【单链表】尾插法建立,头插法就地逆置_第2张图片


 

 1.尾插法图解

 【单链表】尾插法建立,头插法就地逆置_第3张图片


2.头插法 (就地逆置)图解:

         /*就地逆置(头插法)*/    
首先定义两个结点指针 p ,q;分别指向首元结点和次首元结点(p用来遍历,q用来头插) 
接着先让头结点的指针域置为 NULL;
 q先去找 p 所指的结点,让 p 后移遍历链表;
然后让 q 指向的结点进行头插

【单链表】尾插法建立,头插法就地逆置_第4张图片

      学完这些小知识,其实就地逆置还有一种方法:运用递归的。和题目要求不符,所以针对性地进行解答哦。

【单链表】尾插法建立,头插法就地逆置_第5张图片

 

你可能感兴趣的:(C/C++实战,c语言,数据结构,链表)