课程设计:题目0学生档案管理系统

本文介绍了一个使用C++实现的学生信息管理系统,该系统通过链表来管理学生数据,支持学生信息的录入、查找、修改、删除等功能,并能进行成绩排序及文件读写操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<iostream>
#include<fstream>
#include<string>
using namespace std;

struct Node
{
	char name[20];
	int num,chi,math,eng,id;	
	Node *next;
};

class Student
{
private:
	Node *head;
public:
	Student();
	~Student();
	void LinkList();                                        //建立链表 
	void Find();                                            //查找
	void Insert(char *na,int i,int ch,int ma,int en);       //插入
	void Delete();                                          //删除
	void Modify();                                          //修改
	void Sort();                                            //排序,按总成绩按从小到大排序
	void Copy(Node *temp,Node *p);                          //拷贝
	void Print();                                           //显示
    void Read();                                            //读入
	void Save();                                            //保存
};


Student::Student()
{
	head = new Node;
	head->next = NULL;
}

Student::~Student()
{
	Node *p;
	while(head)
	{
		p = head;
		head = head->next;
		delete p;
	}
	head = NULL;
}

void Student::LinkList()
{
	int i,n;
	Node *p,*q;
	cout<<"输入学生人数:";
	cin>>n;
	i=0;
	q=head;
	cout<<"输入学生信息:姓名 学号 语文、数学、英语成绩:"<<endl;
	for(i=0;i<n;i++)
	{
		char na[20];
		int x,ch,ma,en;
		cin>>na>>x>>ch>>ma>>en;
		Node *a;
	    a = head;
	    while(a->next && a->id!=x)
		{a = a->next;}
		if(a->id==x) {cout<<"该学号已存在"<<endl; return ;}  //判断学号是否重复
		else
		{
			p = new Node;
			strcpy(p->name,na);
			p->chi=ch;
			p->id=x;
			p->math=ma;
			p->eng=en;
			p->num=p->chi+p->math+p->eng;
			p->next=q->next;
			q->next=p;
			p = p->next;
		}
	}
}

void Student::Find()
{
	cout<<"请输入要查找学生的学号:";int i;
    cin>>i;
	Node *p;
	p = head->next;
	while(p->next && p->id!=i)
	{p = p->next;}
	if(p->id==i)
	{
		cout<<"学生信息:姓名:"<<p->name<<" 语文:"<<p->chi<<" 数学:"<<p->math<<" 英语:"<<p->eng<<" 总成绩:"<<p->num<<endl;
	}
	else cout<<"未找到该学生信息!"<<endl;
}

void Student::Insert(char *na,int i,int ch,int ma,int en)
{
	Node *p,*q;
	p = new Node;
	strcpy(p->name,na);
	p->id = i;
	p->chi = ch;
	p->math = ma;
	p->eng = en;
    p->num=ch+ma+en;
	q = head;
	p->next=q->next;
	q->next = p;
}

void Student::Delete()
{
	cout<<"请输入要查找学生的学号:";int i;
    cin>>i;
	Node *p,*temp;
	p = head->next;
	while(p->next && p->id!=i)
	{p = p->next;}
	if(p->id==i)
	{
		temp = p->next;
		p->next = temp->next;
		delete temp;
	}
	else 
	{
		cout<<"未找到该学生信息!"<<endl;
	}
}

void Student::Modify()
{
	cout<<"请输入需要修改学生信息的学号:";int i;
	cin>>i;
	Node *p;
	p = head->next;
	while(p->next && p->id!=i)
	{p = p->next;}
	if(p->id==i)
	{
		char na[20];
		int ch,ma,en;
		cout<<"请输入新的姓名、语文成绩、数学成绩、英语成绩:";
		cin>>na>>ch>>ma>>en;
		strcpy(p->name,na);
		p->chi = ch;
		p->math = ma;
		p->eng = en;
		p->num=ch+ma+en;
	}
	else
	{
		cout<<"未找到该学号!"<<endl;
	}
}

void Student::Copy(Node *temp,Node *p)
{
	if(p == NULL)
	{
		cout<<"拷贝目标为空!"<<endl;
	}
	else
	{
		strcpy(temp->name,p->name);
		temp->num = p->num;
		temp->chi = p->chi;
		temp->math = p->math;
		temp->eng = p->eng;
		temp->id = p->id;
	}
}

void Student::Sort()
{
	for(Node *p = head->next; p!=NULL; p=p->next)
		for(Node *q = head->next; q!=NULL; q=q->next)
		{
			Node *temp = new Node;
			Copy(temp,p);
			Copy(p,q);
			Copy(q,temp);
		}
}

void Student::Print()
{
	Node *p;
	for(p = head->next; p!=NULL; p = p->next)
	{
		cout<<"姓名:"<<p->name<<" 学号:"<<p->id<<" 语文:"<<p->chi<<" 数学:"<<p->math<<" 英语:"<<p->eng<<" 总成绩:"<<p->num<<endl;
	}
}

void Student::Read()
{
	Node *p;
	p = head;
	ifstream in("Student.txt");
	if(!in)
	{
		cout<<"文件是空的。\n";
		return ;
	}
	char na[20];
	while(in>>na)
	{	
		int i,chi,ma,en;
		in>>i>>chi>>ma>>en;
		Insert(na,i,chi,ma,en);
	}
	in.close();
}

void Student::Save()
{
	Node *p;
	p = head->next;
	ofstream out("Student.txt");
	if (!out) 
	{
		cout<<"无法打开文件。\n";
		return ;
	}
	while(p != NULL)
	{
		out<<p->name<<" "<<p->id<<" "<<p->chi<<" "<<p->math<<" "<<p->eng<<'\n';
		p = p->next;
	}
	out.close();
}

void menu()
{
	cout<<"*******************      1.录入学生信息      *******************"<<endl;
	cout<<"*******************      2.插入学生信息      *******************"<<endl;
	cout<<"*******************      3.修改学生信息      *******************"<<endl;
	cout<<"*******************      4.删除学生信息      *******************"<<endl;
	cout<<"*******************      5.查找学生信息      *******************"<<endl;
	cout<<"*******************      6.输出学生信息      *******************"<<endl;
	cout<<"*******************      7.按成绩排序        *******************"<<endl;
	cout<<"*******************      8.文件读入学生信息  *******************"<<endl;
	cout<<"*******************      9.保存学生信息      *******************"<<endl;
	cout<<"*******************      0.安全退出          *******************"<<endl;
}

int main()
{
	Student s;
	int choice;
	while(choice!=0)
	{
		menu();
		cout<<"请输入选项:";
		cin>>choice;
		if(choice>=0 && choice<=8)
			switch(choice)
		{
			case 0:s.Save(); break;
			case 1:s.LinkList();break;
			case 2:
				cout<<"请输入要插入学生的姓名、学号、语文成绩、数学成绩、英语成绩:";
				char na[20];
				int i, ch, ma, en;
				cin>>na>>i>>ch>>ma>>en;  
				s.Insert(na,i,ch,ma,en);
				break;
			case 3:s.Modify(); break;
			case 4:s.Delete(); break;
			case 5:s.Find(); break;
			case 6:s.Print(); break;
			case 7:s.Sort(); break;
			case 8:
				s.Read();
				cout << "读入学生信息表:" << endl;
				s.Print(); break;
			case 9:s.Save(); break;
		}
	}
	return 0;
}

1、某商业集团的销售管理系统 数据库中有三个实体集。一是"商店"实体集,属性有商店编号、商店名、地址等;二 是"商品"实体集,属性有商品号、商品名、规格、单价等;三是"职工"实体集,属性有 职工编号、姓名、性别、业绩等。 商店与商品间存在"销售"联系,每个商店可销售多种商品,每种商品也可放在多个商 店销售,每个商店销售一种商品,有月销售量;商店与职工间存在着"聘用"联系,每个 商店有许多职工,每个职工只能在一个商店工作,商店聘用职工有聘期和月薪。 1. 试画出ER图,并在图上注明属性、联系的类型。 2. 将ER图转换成关系模型,并注明主键和外键。 解:(1) ER图如图5.1所示。 M 1 N N 图5.1 (2)这个ER图可转换4个关系模式: 商店(商店编号,商店名,地址) 职工(职工编号,姓名,性别,业绩,商店编号,聘期,月薪) 商品(商品号,商品名,规格,单价) 销售(商店编号,商品号,月销售量) 2、设某商业集团的仓库管理系统 数据库有三个实体集。一是"公司"实体集,属性有公司编号、公司名、地址等;二是 "仓库"实体集,属性有仓库编号、仓库名、地址等;三是"职工"实体集,属性有职工编 号、姓名、性别等。 公司与仓库间存在"隶属"联系,每个公司管辖若干仓库,每个仓库只能属于一个公司管 辖;仓库与职工间存在"聘用"联系,每个仓库可聘用多个职工,每个职工只能在一个仓 库工作,仓库聘用职工有聘期和工资。 1) 试画出ER图,并在图上注明属性、联系的类型。 2) 将ER图转换成关系模型,并注明主键和外键。 解:(1) ER图如图5.2所示。 1 N 1 N 图5.2 (2)这个ER图可转换3个关系模式: 公司(公司编号,公司名,地址) 仓库(仓库编号,仓库名,地址,公司编号) 职工(职工编号,姓名,性别,仓库编号,聘期,工资) 3、 设某商业集团的商品供应管理系统 数据库有三个实体集。一是"商品"实体集,属性有商品号、商品名、规格、单价等; 二是"商店"实体集,属性有商店号、商店名、地址等;三是"供应商"实体集,属性有供 应商编号、供应商名、地址等。 供应商与商品之间存在"供应"联系,每个供应商可供应多种商品,每种商品可向多个 供应商订购,每个供应商供应每种商品有个月供应量;商店与商品间存在"销售"联系, 每个商店可销售多种商品,每种商品可在多个商店销售,每个商店销售每种商品有个月 计划数。 试画出反映上述问题的ER图,并将其转换成关系模型。 解:ER图如图5.3所示。 M M N N 图5.3 (2)这个ER图可转换5个关系模式: 供应商(供应商编号,供应商名,地址) 商店(商店号,商店名,地址) 商品(商品号,商品名,规格,单价) 供应(供应商编号,商品号,月供应量) 销售(商店号,商品号,月计划数) 4、 银行储蓄业务管理系统 数据库中涉及到储户、存款、取款等信息。试设计ER模型。 解:储蓄业务主要是存款、取款业务,可设计如图5.4所示的ER图。 1 1 N N 图5.4 5、体育项目比赛管理系统。 数据库有锦标赛各个代表团、运动员、比赛项目、比赛情况等实体。 解:图5.5是ER图的一种设计方案。 图5.5 6、超市管理系统。 该超市公司的业务管理规则如下: 该超市公司有若干仓库,若干连锁商店,供应若干商品。 每个商店有一个经理和若干收银员,每个收银员只在一个商店工作。 每个商店销售多种商品,每种商品可在不同的商店销售。 每个商品编号只有一个商品名称,但不同的商品编号可以有相同的商品名称。每种 商品可以有多种销售价格。 超市公司的业务员负责商品的进货业务。 试按上述规则设计ER模型 解:图5.6是ER图的一种设计方案。 图5.6 7、学生管理系统 假设要根据某大学的系、学生、班级、学会等信息建立一个数据库,一个系有若干专 业,每个专业每年只招一个班,每个班有若干学生。一个系的学生住在同一宿舍区。每 个学生可以参加多个学会,每个学会有若干学生,学生参加某学会有个入会年份。试为 该大学的系、学生、班级、学会等信息设计一个ER模型。 解:图5.7是ER图的一种设计方案。 图5.7 8、公司车队信息系统 本例为某货运公司设计了车队信息管理系统,对车辆、司机、维修、保险、报销等信 息和业务活动进行管理。其ER图如图5.8所示。 该ER图有7个实体类型,其结构如下: 部门(部门号,名称,负责人) 车队(车队号,名称,地址) 司机(司机号,姓名,执照号,电话,工资) 车辆(车牌号,车型,颜色,载重) 保险公司(保险公司号,名称,地址) 维修公司(维修公司号,名称,地址) 开销(顺序号,费用类型,费用,日期,经手人) 实体之间有7个联系,其中6个是1:N联系,1个是M:N联系。其中联系的属性如下: 调用(出车编号,出车日期,车程,费用,车
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值