单链表的简单函数定义

el/2023/6/3 16:33:47

单链表的函数定义

#include <stdio.h>
#include <stdlib.h>#define ElemType int//判断单链表是否为空
bool Empty(LinkList L) {return (L == NULL);
}//定义单链表结点类型
typedef struct LNode{			ElemType data ;				//数据域struct LNode *next ;		//指针域
}LNode , *LinkList ;//初始化一个单链表(带头结点)
bool InitList(LinkList &L) {		L = (LNode *)malloc(sizeof(LNode));if (L == NULL)return false;elsereturn true;						
}//查找第i个位置
bool ListSearch(LinkList &L, int i) {if (i < 1)return false;LNode *p;		//指针p指向当前扫描到的结点int j = 0;			//当前p指向的是第几个结点p = L;				//L指向头结点,头结点是第0个结点(不存数据)while (p != NULL && j < i - 1) {		//循环找到第i-1的个结点  —— i-1=0p = p->next;j++;}
}//在第i个位置插入元素e(带头结点)				——按位序插入
bool ListInsert1(LinkList &L, int i, ElemType e) {if (i < 1)return false;LNode *p;		//指针p指向当前扫描到的结点int j = 0;			//当前p指向的是第几个结点p = L;				//L指向头结点,头结点是第0个结点(不存数据)while (p != NULL && j < i - 1) {		//循环找到第i-1的个结点  —— i-1=0p = p->next;j++;}if (p == NULL)			//i值不合法return false;LNode *s = (LNode *)malloc(sizeof(LNode));s->data = e;	s->next = p->next;						//将结点s连到p之后p->next = s;									//插入成功return true;
}//后插操作:在p结点之后插入元素e
bool InsertNextNode(LNode *p, ElemType e) {if (p == NULL)return false;LNode *s = (LNode *)malloc(sizeof(LNode));if (s == NULL)			//内存分配失败return false;s->data = e;							//用结点s保存数据元素es->next = p->next;p->next = s;							//将结点s连接到p之后return true;
}//前插操作:在p结点之前插入元素e
bool InsertpriorNode(LNode *p, ElemType e) {if (p == NULL)return false;LNode *s = (LNode *)malloc(sizeof(LNode));if (s = NULL)return false;							//内存分配失败s->next = p->next;						//p->next = s;									//将结点s连到p的后面s->data = p->data;						//将p的数据复制到s中p->data = e;								//p中元素覆盖为e
}//指定结点的后插		
bool ListInsertNext(LinkList &L, int i, ElemType e) {if (i < 1)return false;LNode *p;		//指针p指向当前扫描到的结点int j = 0;			//当前p指向的是第几个结点p = L;				//L指向头结点,头结点是第0个结点(不存数据)while (p != NULL && j < i - 1) {		//循环找到第i-1的个结点  —— i-1=0p = p->next;j++;}return InsertNextNode(p, e);
}//指定结点的前插
bool ListInsertPrior(LinkList &L, int i, ElemType e) {if (i < 1)return false;LNode *p;		//指针p指向当前扫描到的结点int j = 0;			//当前p指向的是第几个结点p = L;				//L指向头结点,头结点是第0个结点(不存数据)while (p != NULL && j < i - 1) {		//循环找到第i-1的个结点  —— i-1=0p = p->next;j++;}return InsertpriorNode(p, e);
}//指定结点的删除
bool DeleteNode(LNode *p) {					//删除指定结点pif (p == NULL)return false;								//删除失败,无此结点LNode *q = p->next;						//令q指向*p的后继结点p->data = p->next->data;				//和后继结点交换数据域p->next = q->next;							//将*q结点从链中“断开”free(q);												//释放后继结点的存储空间return true;										//删除成功//指定结点是最后一个结点时,需要特殊处理
}//按位序删除(带头结点)
bool ListDelete(LinkList &L, int i, ElemType &e) {if (i < 1)return false;LNode *p;				//指针p指向当前扫描到的结点int j = 0;					//当前p指向的是第几个结点p = L;						//p指向头结点,头结点是第0个结点while (p != NULL && j < i - 1) {p = p->next;j++;}if (p = NULL)				//i值不合法	return false;			if (p->next = NULL)		//在第i-1个结点之后已无其他结点return false;LNode *q = p->next;				//令q结点指向被删除结点e = q->data;							//用e返回元素的值p->next = q->next;					//将*q结点从链中断开free(q);										//释放结点的存储空间return true;								//删除成功
}
http://www.ngui.cc/el/413289.html

相关文章

《MFC如何屏蔽ESC和Enter按键退出应用程序》

问题描述 创建MFC应用程序的时候&#xff0c;通常可以通过ESC按键退出应用程序程序&#xff0c;Enter按键来执行当前选中的操作&#xff0c;有时候ESC和Enter有其他的功能&#xff0c;需要屏蔽掉&#xff0c;该怎么办呢&#xff1f;MFC其实已经为我们准备好了&#xff0c;我们只…