单链表的基本操作(一)——沐雨先生

C,数据结构

目录

        1、理解单链表的结构特点。

        2、掌握单链表的基本操作。

二、实验内容

1、建立并输出一个单链表。

        A.首先要定义单链表的数据结构;

        B.  编写一个函数使用“头插法”或“尾插法”创建一个单链表,例如:

           LinkList  createList(LinkList  L,int n){

                    ………

           } 

        C.编写一个函数(showList)能够显示一个单链表中各结点的值。

        D、编写一个函数(freeList)能够将单链表中的各个结点都释放。

        E、 编写主函数(main) 。

        F、 以下的部分代码仅供参考。

三、源程序

#include<stdio.h>
#include<stdlib.h>
#define OK 1
#define ERROR 0
#define OVERFLOW -2

typedef struct LNode{
	int data;
	struct LNode *next;
}LNode,*LinkList;//声明
//LNode是结构体类型名,*LinkList是指向结构体的普通指针,相当于LNode *LinkList这样的定义,LNode *p中p是结构体指针,非普通指针,LinkList p中p是普通指针,指向LNode类型结构体的指针

LinkList createList(LinkList L,int n){//头插法//L就是指针,下面才是->
	int i;
	LinkList p;
	L=(LinkList) malloc (sizeof(LNode)); //LinkList就是*类型
	L->next=NULL;
	for(i=1;i<=n;i++){
		p=(LinkList) malloc (sizeof(LNode));   
		scanf("%d",&p->data);//书上为类c语言
		p->next=L->next;
		L->next=p;
	}
	return L;
}

LinkList createList(LinkList L,int n){//尾插法
	int i;
	LinkList p,q;
	L=(LinkList) malloc (sizeof(LNode));
	L->next=NULL;
	q=L;
	for(i=1;i<=n;i++){
		p=(LinkList) malloc (sizeof(LNode));
		scanf("%d",&p->data);
		q->next=p;
		q=p;
	}
	q->next=NULL;
	return L;
}

void showList(LinkList L){//输出带头结点的单链表L中各个结点的值,不包括头结点
	LinkList p;
	p=L->next;
	while(p){
		printf("%d ",p->data);
		p=p->next;
	}
}

void freeList(LinkList L){//将带头结点的单链表L的各个结点都释放
	LinkList p,q;
	p=L->next;
	while(p){
		q=p->next;
		free(p);
		p=q;
	}
}

void main(){
	LinkList La=NULL;//整个节点是空吗
	La=createList(La,5);//创建带头结点单链表La,如果需要La递增,注意自己录入数据的次序
	showList(La);//显示带头结点单链表La中各个结点的值
	//可以用类似的方法创建带头结点的单链表Lb
	freeList(La);//释放La中的各个结点(包括头结点)
}

//Status ListInsert_L(LinkList &L,int i,ElemType e){
//	p=L;j=0;
//	while(p&&j<i-1)
//	{
//		p=p->next;++j;
//	}
//	if(!p || j>i-1)return ERROR;
//	s=(LinkList)malloc(sizeof(LNode));
//	s->data=e;
//	s->next=p->next;
//	p->next=s;
//	return OK;
//}//插入元素

四、运行结果

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沐雨先生

如果真的帮助到你了再打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值