IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> c 链式学生管理系统 -> 正文阅读

[数据结构与算法]c 链式学生管理系统

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>
//首先保证自己选择的数据结构(链表)的实现没问题
struct student 
{
	char name[20];
	char num[20];
	int math;
	int english;
	int py;
	int sum;			//总分
	int average;		//平均分
};
//所有关于数据的地方都要修改
struct Node
{
	struct student  data;
	struct Node* next;
};
struct Node* list;
//创建表头-->创建结构体变量
struct Node* createHead()
{
	struct Node* headNode = (struct Node*)malloc(sizeof(struct Node));
	assert(headNode);			//断言
	headNode->next = NULL;
	return headNode;
}
struct Node* createNode(struct student data)
{
	struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
	assert(newNode);
	//->
	newNode->data = data;
	(*newNode).next = NULL;
	return newNode;
}
void insertData(struct Node* headNode, struct student data)
{
	struct Node* newNode = createNode(data);
	newNode->next = headNode->next;
	headNode->next = newNode;
}
void printList(struct Node* headNode) 
{
	struct Node* pmove = headNode->next;
	printf("姓名\t编号\t数学\t英语\tpy\t总分\t平均分\n");
	while (pmove != NULL) 
	{
		printf("%s\t%s\t%d\t%d\t%d\t%d\t%d\n", pmove->data.name,
			pmove->data.num, pmove->data.math, pmove->data.english, pmove->data.py, 
			pmove->data.sum, pmove->data.average);
		pmove = pmove->next;
	}
}
void deleteDataByName(struct Node* headNode, const char* name)
{
	struct Node* preNode = headNode;
	struct Node* curNode = headNode->next;
	while (curNode != NULL && strcmp(curNode->data.name,name)) 
	{
		preNode = curNode;
		curNode = preNode->next;
	}
	if (curNode==NULL) 
	{
		printf("删除失败!,没有找到指定数据!\n");
	}
	else 
	{
		preNode->next = curNode->next;
		free(curNode);
	}
}
struct Node* searchDataByName(struct Node* headNode, const char* name) 
{
	struct Node* pmove = headNode->next;
	while (pmove != NULL && strcmp(pmove->data.name,name)) 
	{
		pmove = pmove->next;
	}
	return pmove;
}
//管理系统文件操作
//写文件
void saveToFile(struct Node* headNode, const char* fileName) 
{
	struct Node* pmove = headNode->next;
	FILE* fp = fopen(fileName, "w");
	while (pmove != NULL) 
	{
		fprintf(fp, "%s\t%s\t%d\t%d\t%d\t%d\t%d\n", pmove->data.name,
			pmove->data.num, pmove->data.math, pmove->data.english, pmove->data.py,
			pmove->data.sum, pmove->data.average);
		pmove = pmove->next;
	}
	fclose(fp);
}
//读文件
void readFromFile(struct Node* headNode, const char* fileName) 
{
	FILE* fp = fopen(fileName, "r");
	if (fp == NULL) 
	{
		fp = fopen(fileName, "w+");
		fclose(fp);
	}
	struct student temp;
	while (fscanf(fp, "%s\t%s\t%d\t%d\t%d\t%d\t%d\n",
		temp.name,
		temp.num,
		&temp.math,
		&temp.english,
		&temp.py,
		&temp.sum,
		&temp.average) != EOF) 
	{
		insertData(list, temp);
	}
	fclose(fp);
}
void makeMenu()		  //制作菜单
{
	//排序+文件
	printf("---------【链式学生管理系统】---------\n");
	printf("\t\t0.退出功能\n");
	printf("\t\t1.录入功能\n");
	printf("\t\t2.浏览功能\n");
	printf("\t\t3.查找功能\n");
	printf("\t\t4.修改功能\n");
	printf("\t\t5.删除功能\n");
	printf("-------------------------------------\n");
	printf("请输入(0~5):");
}
void keyDown() 
{
	int userkey = 0;
	struct student temp;			//接受用户的输入
	struct Node* result;
	scanf_s("%d", &userkey);
	switch (userkey) 
	{
	case 0:
		printf("----【退出模块】----\n");
		system("pause");
		exit(0);
		break;
	case 1:
		printf("----【录入模块】----\n");
		printf("请输入学生信息(name,num,math,english,py):");
		scanf_s("%s%s%d%d%d", temp.name, 20, temp.num, 20, &temp.math, &temp.english, &temp.py);
		//手动处理:
		temp.sum = temp.math + temp.english + temp.py;
		temp.average = temp.sum / 3;
		insertData(list, temp);
		saveToFile(list, "student.txt");
		break;
	case 2:
		printf("----【浏览功能】----\n");
		printList(list);
		break;
	case 3:
		printf("----【查找功能】----\n");
		printf("请输入要查找学生姓名:");
		scanf_s("%s", temp.name,20);  //vs 增强版的函数,20 代表长度
		result = searchDataByName(list, temp.name);
		if (result == NULL) 
		{
			printf("未找到结果!\n");
		}
		else 
		{
			printf("姓名\t编号\t数学\t英语\tpy\t总分\t平均分\n");
			printf("%s\t%s\t%d\t%d\t%d\t%d\t%d\n",
				result->data.name,
				result->data.num, 
				result->data.math, 
				result->data.english, 
				result->data.py,
				result->data.sum, 
				result->data.average);
		}
		break;
	case 4:
		printf("----【修改功能】----\n");
		printf("请输入要修改学生姓名:");
		scanf_s("%s", temp.name, 20);  //vs 增强版的函数,20 代表长度
		result = searchDataByName(list, temp.name);
		if (result == NULL)
		{
			printf("未找到结果!\n");
		}
		else
		{
			printf("请输入学生新的信息(name,num,math,english,py):");
			scanf_s("%s%s%d%d%d", result->data.name, 20, result->data.num, 20, &result->data.math, &result->data.english, &result->data.py);
			//手动处理:
			result->data.sum = result->data.math + result->data.english + result->data.py;
			result->data.average = result->data.sum / 3;
			saveToFile(list, "student.txt");
		}
		break;
	case 5:
		printf("----【删除功能】----\n");
		printf("请输入要删除学生姓名:");
		scanf_s("%s", temp.name, 20);  //vs 增强版的函数,20 代表长度
		deleteDataByName(list, temp.name);
		saveToFile(list, "student.txt");
		break;
	default:
		printf("输入错误!,请重新输入...!\n");
		break;
	}
}
int main() 
{
	list = createHead();
	readFromFile(list, "student.txt");
	while (1) 
	{
		makeMenu();
		keyDown();
		system("pause");		//按任意键继续
		system("cls");			//清屏
	}
	return 0;
}
/*
	C/C++  一定编程基础
	做业务的技术
	 框架:Qt
	 通用性技术
	   1.数据库编程
	   2.网络编程
	   3.多线程编程

*/
/*
	做外挂,做辅助工具
	逆向: 汇编-->反汇编工具,内存,网络
	C/C++--->内存
	抓包-解包
*/

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-02-26 11:55:08  更:2022-02-26 12:00:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 2:20:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码