c语言课程设计高校学籍管理系统

c语言学籍管理系统,采用链表书写,部分代码如下:


class CUserdlg : public CDialog
{
// Construction
public:
	void DisplayRecord();
	CUserdlg(CWnd* pParent = NULL);   // standard constructor
	CImageList m_ImageList;
	CLoginSet* m_LoginSet;
// Dialog Data
	//{{AFX_DATA(CUserdlg)
	enum { IDD = IDD_Dlguser };
	CListCtrl	m_List;
	CString	m_Name;
	CString	m_PassWord;
	//}}AFX_DATA


// Overrides
	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CUserdlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:

	// Generated message map functions
	//{{AFX_MSG(CUserdlg)
	virtual BOOL OnInitDialog();
	afx_msg void OnClose();
	afx_msg void OnButtadd();
	afx_msg void OnButmod();
	afx_msg void OnClickList1(NMHDR* pNMHDR, LRESULT* pResult);
	afx_msg void OnButdel();
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

class CTeacherinfoset : public CRecordset
{
public:
	CTeacherinfoset(CDatabase* pDatabase = NULL);
	DECLARE_DYNAMIC(CTeacherinfoset)

// Field/Param Data
	//{{AFX_FIELD(CTeacherinfoset, CRecordset)
	CString	m_teacherid;
	CString	m_teachername;
	CString	m_sex;
	CString	m_office;
	CString	m_knowledge;
	CString	m_Level;
	//}}AFX_FIELD


// Overrides
	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CTeacherinfoset)
	public:
	virtual CString GetDefaultConnect();    // Default connection string
	virtual CString GetDefaultSQL();    // Default SQL for Recordset
	virtual void DoFieldExchange(CFieldExchange* pFX);  // RFX support
	//}}AFX_VIRTUAL

// Implementation
#ifdef _DEBUG
	virtual void AssertValid() const;
	virtual void Dump(CDumpContext& dc) const;
#endif
};

一、学籍管理系统 1.问题提出 为了分析教学效果并进相应的学籍处理,各学校每到期末都对综合成绩进分类统计、上报成绩汇总结果等,这给每位老师和学籍管理人员带来很大工作量。使用学籍管理系统可以减少工作者的工作负担。 2.功能要求 循环显示如图7(a)所示的主菜单。 ………………………………………………….        .………………………………………………………        …………………………………………………………. 请输入选项编号(0 ~4):.        . 请输入选项编号(0 ~4):.        .请输入选项编号(0 ~4):. ………………………………………………….        .………………………………………………………        …………………………………………………………. . 1——录入成绩.                . 1——按学号排序.               . 1——生成并打印补考通知单 . . 2——统计成绩.                . 2——计算平均分并排序 .         . 2——生成并打印退学通知单 . . 3——处理学籍.                . 3——统计分数段.               . 3——生成并打印新名册. . 4——创新功能.                . 4——返回.                    . 4——返回. . 0——退出系统.                . 0——退出系统.                 . 0——退出系统. ……………………………………………………         ……………………………………………………….        …………………………………………………………. 图7(a) 学籍管理主菜单            (b)成绩统计子菜单               (c)学籍处理子菜单 在主菜单中选择1:录入成绩。假设某班的原始成绩形式如下: 学号        姓名        高数    英语    物理    编程    马哲 0909339105 Huangying  89      92      85     88     82 0909339102 Zhangchen  72      68      83     90     78 0909339108 Linan      91      84      90     79     81 …… 其中,原始数据的排列是无序的。系统应能够保留原始成绩单。 在主菜单中选择2:进入如图7(b)所示的子菜单,并统计成绩。在此可以计算平均分、统计各分数段、按学号排序、按平均分排序。在子菜单选择1时,将该班学生的成绩按学号升序排序后的顺序存入std.dat文件中,以方便打印。在子菜单选择2时,求出每位学生的平均分,并按平均分从高到低的顺序进排序后,写入文件sort.dat中。在子菜单选择3时,统计出各门课、各分数段学生的人数,并如表1所示的形式输出。在子菜单选择4时,返回主菜单;选择0,退出整个系统。 在主菜单选择3:进入如图7(c)所示的子菜单,并处理学籍。为不及格的学生打印重考通知单时,应在通知单上写明重考的课程、时间和地点(由键盘输入)。为了参加多门课重考的学生完成补考,应避免时间重复。为3门以上不及格的学生打印退学通知单。通知单上应写明学生的学号、姓名、退学原因(几门课不及格,成绩多少)。删除已退学的学生信息,将该班中升入高年级的学生信息写入文件next.dat中。在子菜单选择4,返回主菜单;选择0,退出整个系统。 在主菜单中选择4:此项功能学生自由发挥,根据本组爱好增加与本题止相关的新功能。 在主菜单中选择0:显示结束信息(如“感谢使用本软件!已正常退出,按任意键结束。”),按任意键后,退出本功能。 表1 各门课、各分数段学生的人数 ……………………………………………………………………………………………………………….   . 90以上. 80~89分.70~79分.60~69分.60分以下. 高数.      .       .       .       .       . 英语.      .       .       .       .       . 物理.      .       .       .       .       . 编程.      .       .       .       .       . 马哲.      .       .       .       .       . ……………………………………………………………………………………………………………….
以下是一个简单的小型高校学生学籍管理系统的示例,基于C语言实现。这个示例仅包含了基本的学生信息管理和查询功能,其他功能可以根据需要进扩展。 ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_STUDENT_NUM 100 struct Student { char name[20]; char gender[10]; int age; char hometown[50]; }; struct Student students[MAX_STUDENT_NUM]; int studentNum = 0; void addStudent(); void searchStudent(); int main() { int choice; do { printf("1. Add student\n"); printf("2. Search student\n"); printf("3. Exit\n"); printf("Enter your choice: "); scanf("%d", &choice); switch (choice) { case 1: addStudent(); break; case 2: searchStudent(); break; case 3: printf("Bye!\n"); break; default: printf("Invalid choice, please try again.\n"); break; } } while (choice != 3); return 0; } void addStudent() { if (studentNum >= MAX_STUDENT_NUM) { printf("Sorry, the maximum number of students has been reached.\n"); return; } struct Student student; printf("Please enter the student's information:\n"); printf("Name: "); scanf("%s", student.name); printf("Gender: "); scanf("%s", student.gender); printf("Age: "); scanf("%d", &student.age); printf("Hometown: "); scanf("%s", student.hometown); students[studentNum] = student; studentNum++; printf("Student added successfully!\n"); } void searchStudent() { char name[20]; printf("Please enter the student's name: "); scanf("%s", name); int found = 0; for (int i = 0; i < studentNum; i++) { if (strcmp(students[i].name, name) == 0) { printf("Student found:\n"); printf("Name: %s\n", students[i].name); printf("Gender: %s\n", students[i].gender); printf("Age: %d\n", students[i].age); printf("Hometown: %s\n", students[i].hometown); found = 1; break; } } if (!found) { printf("Student not found.\n"); } } ``` 这个示例中,我们定义了一个结构体 `Student` 来存储学生的基本信息,包括姓名、性别、年龄和籍贯。我们使用一个全局数组 `students` 来存储所有的学生信息,最大容量为 `MAX_STUDENT_NUM`。我们还定义了一个全局变量 `studentNum` 来记录当前已经添加的学生数量。 在 `main` 函数中,我们展示了一个菜单,让用户可以选择添加学生或者查询学生。对于每个选择,我们都调用相应的函数来处理。 在 `addStudent` 函数中,我们首先检查学生数量是否超过了最大容量。如果没有超过,就让用户输入学生的基本信息,并将其添加到 `students` 数组中。 在 `searchStudent` 函数中,我们让用户输入要查询的学生姓名,然后遍历 `students` 数组,查找与之匹配的学生信息。如果找到了,就输出学生的基本信息,否则就提示未找到。 这个示例只是一个简单的示例,还可以根据需要进扩展,添加更多的功能和更复杂的数据结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

qq_51741751

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

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

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

打赏作者

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

抵扣说明:

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

余额充值