我是靠谱客的博主 受伤黄豆,最近开发中收集的这篇文章主要介绍数据结构与算法 | 头插法和尾插法图文并茂,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

原文链接:http://blog.csdn.net/Fire_Sky_Ho/article/details/78072052?locationNum=4&fps=1

 

#include "stdio.h"
#include "stdlib.h"
typedef struct List 
{
	int data; //数据域
	struct List *next; //指针域
} List;
void TailCreatList(List *L) //尾插法建立链表
{
	List *s, *r;//s用来指向新生成的节点。r始终指向L的终端节点。
	r = L; //r指向了头节点,此时的头节点是终端节点。
	for (int i = 0; i < 10; i++) {
	s = (struct List*) malloc(sizeof(struct List));//s指向新申请的节点
	s->data = i; //用新节点的数据域来接受i
	r->next = s; //用r来接纳新节点
	r = s; //r指向终端节点
	}
	r->next = NULL; //元素已经全部装入链表L中
	//L的终端节点指针域为NULL,L建立完成
}
void HeadCreatList(List *L) //头插法建立链表
{
	List *s; //不用像尾插法一样生成一个终端节点。
	L->next = NULL;
	for (int i = 0; i < 10; i++) {
	s = (struct List*) malloc(sizeof(struct List));
	s->data = i;
	s->next = L->next; //将L指向的地址赋值给S;//头插法与尾插法的不同之处主要在此,
	//s所指的新节点的指针域next指向L中的开始节点
	L->next = s; //头指针的指针域next指向s节点,使得s成为开始节点。
	}
}
void DisPlay(List *L) 
{ 	//打印节点
	List *p = L->next;
	while (p != NULL) {
	printf("%d ", p->data);
	p = p->next;
	}
	printf("n");
}
int main() 
{
	List *L1, *L2;
	L1 = (struct List*) malloc(sizeof(struct List));
	L2 = (struct List*) malloc(sizeof(struct List));
	HeadCreatList(L1);
	DisPlay(L1);
	TailCreatList(L2);
	DisPlay(L2);
}

程序运行结果如下:

 

最后

以上就是受伤黄豆为你收集整理的数据结构与算法 | 头插法和尾插法图文并茂的全部内容,希望文章能够帮你解决数据结构与算法 | 头插法和尾插法图文并茂所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部