数据结构----单链表

来源:微信公众号「编程学习基地」

单链表

单链表的定义

链式存储的线性表

在这里插入图片描述

在这里插入图片描述

定义单链表的结构体
typedef struct student
{
	int m_id;
	char m_name[20];
	int m_score;
	struct student *pNext;
}STU;
初始化函数
STU* Init()
{
	STU* pNew = (STU*)malloc(sizeof(STU));
	pNew->pNext = NULL;
	return pNew;
}
添加数据

在这里插入图片描述

void Insert(STU* pHead, STU * pData)
{
	STU* pNew = Init();
	pNew->m_id = pData->m_id;
	memcpy(pNew->m_name, pData->m_name, 20);	//字符串不能直接赋值
	pNew->m_score = pData->m_score;
	//中间插入要遍历链表找到插入位置,这里只介绍头插和尾插
#if 0
	//头插
	pNew->pNext = pHead->pNext;	//①
	pHead->pNext = pNew;		//②
#else
	//尾插
	STU* pTemp = pHead;
	while (pTemp->pNext != NULL)
	{
		pTemp = pTemp->pNext;
	}
	pNew->pNext = pTemp->pNext;	//①
	pTemp->pNext = pNew;		//②
#endif
}
删除数据
void DeleteNode(STU* pHead, char name[])
{
	STU* pTemp = pHead;
	while (pTemp->pNext != NULL)
	{
		if (strcmp(pTemp->pNext->m_name, name) == 0)
		{
			STU* pDelete = pTemp->pNext;
			pTemp->pNext = pDelete->pNext;
			free(pDelete);
			break;
		}
		pTemp = pTemp->pNext;
	}
	printf("\n删除成功...\n\n");
}
清空内存
void FreeAll(STU * pHead)
{
	STU* pTemp = pHead;
	while (pTemp->pNext != NULL)
	{
		STU* pDelete = pTemp->pNext;
		pTemp->pNext = pDelete->pNext;
		free(pDelete);
	}
}

完整代码(简单版)

main文件:

//main.c
#include<stdio.h>
#include"linked.h"
int main()
{
	STU* pHead = Init();
	char name[20];
	while (1)
	{
		switch (Menu())
		{
		case 1:		//添加学生信息
		{
			STU* pNew = Init();
			printf("请输入学生ID:");
			scanf("%d", &pNew->m_id);
			printf("请输入学生Name:");
			scanf("%s", pNew->m_name);
			printf("请输入学生Score:");
			scanf("%d", &pNew->m_score);
			Insert(pHead, pNew);
		}
			break;
		case 2:		//删除学生信息
			printf("请输入要删除的学生姓名:");
			scanf("%s", name);
			DeleteNode(pHead, name);
			break;
		case 3:		//修改学生信息
			printf("请输入要修改的学生姓名:");
			scanf("%s", name);
			ChangeNode(pHead, name);
			break;
		case 4:		//查找学生信息
			printf("请输入要查询的学生姓名:");
			scanf("%s", name);
			FindNode(pHead, name);
			break;
		case 5:		//显示学生信息
			PrintList(pHead);
			break;
		case 6:		//退出并删除
			FreeAll(pHead);
			return 0;
			break;
		default:
			break;
		}
	}
	return 0;
}

linked.h文件:

#pragma once
#include<stdlib.h>
#include<stdio.h>
#include<string.h>
#include<conio.h>

typedef struct student
{
	int m_id;
	char m_name[20];
	int m_score;
	struct student *pNext;
}STU;

STU* Init();

void Insert(STU* pHead, STU* pData);
void PrintList(STU* pHead);
void DeleteNode(STU* pHead, char name[]);
void ChangeNode(STU* pHead, char name[]);
void FindNode(STU* pHead, char name[]);
void FreeAll(STU* pHead);
int Menu();

linked.c文件:

//linked.c
#include "linked.h"

STU* Init()
{
	STU* pNew = (STU*)malloc(sizeof(STU));
	pNew->pNext = NULL;
	return pNew;
}

void Insert(STU* pHead, STU * pData)
{
	STU* pNew = Init();
	pNew->m_id = pData->m_id;
	memcpy(pNew->m_name, pData->m_name, 20);	//字符串不能直接赋值
	pNew->m_score = pData->m_score;

#if 0
	//头插
	pNew->pNext = pHead->pNext;
	pHead->pNext = pNew;
#else
	//尾插
	STU* pTemp = pHead;
	while (pTemp->pNext != NULL)
	{
		pTemp = pTemp->pNext;
	}
	pNew->pNext = pTemp->pNext;
	pTemp->pNext = pNew;
#endif
}

void PrintList(STU* pHead)
{
	STU* pTemp = pHead->pNext;	//头结点不储存数据
	printf("-------------------------\n");
	printf("ID\tName\tScore\n");
	while (pTemp != NULL)
	{
		printf("%d\t%s\t%d\n", pTemp->m_id, pTemp->m_name, pTemp->m_score);
		pTemp = pTemp->pNext;
	}
	printf("-------------------------\n");
}

void DeleteNode(STU* pHead, char name[])
{
	STU* pTemp = pHead;
	while (pTemp->pNext != NULL)
	{
		if (strcmp(pTemp->pNext->m_name, name) == 0)
		{
			STU* pDelete = pTemp->pNext;
			pTemp->pNext = pDelete->pNext;
			free(pDelete);
			break;
		}
		pTemp = pTemp->pNext;
	}
	printf("\n删除成功...\n\n");
}

void ChangeNode(STU* pHead, char name[])
{
	STU* pTemp = pHead->pNext;
	while (pTemp != NULL)
	{
		if (strcmp(pTemp->m_name, name) == 0)
		{
			printf("-------------------------\n\n");
			printf("请输入修改后的学生ID:");
			scanf("%d", &pTemp->m_id);
			printf("请输入修改后的学生Name:");
			scanf("%s", pTemp->m_name);
			printf("请输入修改后的学生Score:");
			scanf("%d", &pTemp->m_score);
			printf("\n-------------------------\n");
		}
		pTemp = pTemp->pNext;
	}
	printf("\n修改成功...\n\n");
}

void FindNode(STU* pHead, char name[])
{
	STU* pTemp = pHead->pNext;
	printf("-------------------------\n");
	printf("\n查询学生信息表:\n");
	printf("ID\tName\tScore\n");
	while (pTemp != NULL)
	{
		if (strcmp(pTemp->m_name, name) == 0)
		{
			printf("%d\t%s\t%d\n\n", pTemp->m_id, pTemp->m_name, pTemp->m_score);
			printf("-------------------------\n");
			return;
		}
		pTemp = pTemp->pNext;
	}
}

void FreeAll(STU * pHead)
{
	STU* pTemp = pHead;
	while (pTemp->pNext != NULL)
	{
		STU* pDelete = pTemp->pNext;
		pTemp->pNext = pDelete->pNext;
		free(pDelete);
	}
}

int Menu()
{
	char operate;
	do
	{
		printf("菜单:\n");
		printf("1、添加学生信息:\n");
		printf("2、删除学生信息:\n");
		printf("3、修改学生信息:\n");
		printf("4、查找学生信息:\n");
		printf("5、显示学生信息:\n");
		printf("6、退出并删除:\n");
		operate = getch();
	} while (operate > '5' || operate < '1');
	return operate - '0';
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

DeRoy

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值