实现单链表的增删改查

实现单链表的增删改查的功能:头部插入删除/尾部插入删除,查找,在指定位置之前插入数据,删除pos节点,在指定位置之后插入数据,删除pos之后的节点,销毁链表。

SListNode.h

#pragma once
#include
#include
#include
typedef int SLTDataType;
typedef struct SListNode
{
	SLTDataType data;
	struct SListNode* next;
}SLTNode;


void SLTPrint(SLTNode* phead);

//头部插入删除/尾部插入删除
void SLTPushBack(SLTNode** pphead, SLTDataType x);
void SLTPushFront(SLTNode** pphead, SLTDataType x);
void SLTPopBack(SLTNode** pphead);
void SLTPopFront(SLTNode** pphead);

//查找
SLTNode* SLTFind(SLTNode* phead, SLTDataType x);
//在指定位置之前插入数据
void SLTInsert(SLTNode** pphead, SLTNode* pos, SLTDataType x);
//删除pos节点
void SLTErase(SLTNode** pphead, SLTNode* pos);
//在指定位置之后插入数据
void SLTInsertAfter(SLTNode* pos, SLTDataType x);
//删除pos之后的节点
void SLTEraseAfter(SLTNode* pos);
//销毁链表
void SListDesTroy(SLTNode** pphead);

SListNode.c

#define  _CRT_SECURE_NO_WARNINGS
#include"SListNode.h"

void SLTPrint(SLTNode* phead)
{
	SLTNode* pcur = phead;
	while (pcur)
	{
		printf("%d->", pcur->data);
		pcur = pcur->next;
	}
	printf("NULL\n");

}

SLTNode* SLNew( SLTDataType data)
{
	SLTNode* snew = (SLTNode*)malloc(sizeof(SLTNode));
	if (snew == NULL) {
		perror("malloc fail!");
		exit(1);
	}
	snew->next = NULL;
	snew->data = data;
	return snew;
}


//头部插入删除/尾部插入删除
void SLTPushBack(SLTNode** pphead, SLTDataType x)
{
	
	SLTNode* snew = SLNew(x);
	if (*pphead == NULL)
	{
		*pphead = snew;
	}
	else
	{
		SLTNode* pcur = *pphead;
		while (pcur->next)
		{
			pcur = pcur->next;
		}
		pcur->next = snew;
	}

}
void SLTPushFront(SLTNode** pphead, SLTDataType x)
{
	SLTNode* snew = SLNew(x);
	if (*pphead == NULL)
	{
		*pphead = snew;
	}
	else
	{
		SLTNode* pcur = *pphead;
		snew->next = pcur;
		*pphead = snew;
	}
}
void SLTPopBack(SLTNode** pphead)
{
	assert(pphead);
	assert(*pphead);

	SLTNode* pcur = *pphead;
	if (pcur->next == NULL) 
	{
		free(*pphead);
		*pphead = NULL;
		return;
	}
	while (pcur->next->next)
	{
		pcur = pcur->next;
	}
	SLTNode* tmp = pcur->next;
	pcur->next = NULL;
	free(tmp);
	tmp = NULL;
}
void SLTPopFront(SLTNode** pphead)
{
	assert(pphead);
	assert(*pphead);
	SLTNode* pcur = *pphead;
	*pphead = (*pphead)->next;
	free(pcur);
	pcur = NULL;
}

//查找
SLTNode* SLTFind(SLTNode* phead, SLTDataType x)
{
	assert(phead);
	SLTNode* pcur = phead;
	while (pcur)
	{
		if (pcur->data == x)
		{
			return pcur;
		}
		pcur = pcur->next;
	}
	return NULL;
}
//在指定位置之前插入数据
void SLTInsert(SLTNode** pphead, SLTNode* pos, SLTDataType x)
{
	assert(pphead);
	assert(*pphead);
	assert(pos);
	SLTNode* snew = SLNew(x);
	SLTNode* pcur = *pphead;
	if (pos == pcur)
	{
		SLTPushFront(pphead,x);
	}
	else
	{
		while (pcur->next != pos)
		{
			pcur = pcur->next;
		}
		pcur->next = snew;
		snew->next = pos;
	}
}
//删除pos节点
void SLTErase(SLTNode** pphead, SLTNode* pos)
{
	assert(pphead);
	assert(*pphead);
	assert(pos);
	SLTNode* pcur = *pphead;
	if (pcur == pos)
	{
		SLTPopFront(pphead);
	}
	else
	{
		while (pcur->next != pos)
		{
			pcur = pcur->next;
		}
		SLTNode* tmp = pcur->next;
		pcur->next = pcur->next->next;
		free(tmp);
		tmp = NULL;
	}
}
//在指定位置之后插入数据
void SLTInsertAfter(SLTNode* pos, SLTDataType x)
{
	assert(pos);
	SLTNode* snew = SLNew(x);
	snew->next = pos->next;
	pos->next = snew;
}
//删除pos之后的节点
void SLTEraseAfter(SLTNode* pos)
{
	assert(pos);
	assert(pos->next);
	SLTNode* tmp = pos->next;
	pos->next = pos->next->next;
	free(tmp);
	tmp = NULL;
}
//销毁链表
void SListDesTroy(SLTNode** pphead)
{
	assert(pphead);
	assert(*pphead);

	SLTNode* pcur = *pphead;
	while (pcur)
	{
		SLTNode* next = pcur->next;
		free(pcur);
		pcur = next;
	}
	*pphead = NULL;
}

调试函数main

#define  _CRT_SECURE_NO_WARNINGS
#include"SListNode.h"

int main()
{
	SLTNode* ode = NULL;
	SLTPushBack(&ode, 2);
	SLTPrint(ode);
	SLTPushBack(&ode, 3);
	SLTPrint(ode);
	SLTPushFront(&ode, 0);
	SLTPrint(ode);
	SLTInsert(&ode, SLTFind(ode, 2), 9);
	SLTPrint(ode);
	SLTInsertAfter(SLTFind(ode, 0), 7);
	SLTPrint(ode);
	SLTErase(&ode, SLTFind(ode, 2));
	SLTPrint(ode);

	return 0;
}

运行结果

实现单链表的增删改查_第1张图片

你可能感兴趣的:(算法,c语言,数据结构)