vc6.0学生信息管理系统

时间: 2023-12-07 15:04:24 浏览: 43
根据提供的引用内容,VC6.0学生信息管理系统需要实现以下功能: 1. 增加记录:可以连续增加多条记录。 2. 删除记录:可以删除指定学生的记录。 3. 修改记录:可以修改指定学生的记录。 4. 查询记录:可以按照学号或姓名查询指定学生的记录。 5. 排序记录:可以按照学号或成绩对学生记录进行排序。 6. 显示记录:可以显示所有学生的记录。 7. 文件操作:可以打开文件,显示班级的所有学生信息;可以将增加或修改后的成绩重新写入文件;可以将排序好的信息写入新的文件。 下面是一个简单的VC6.0学生信息管理系统的实现,包括增加记录、删除记录、修改记录、查询记录、排序记录和显示记录的功能: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_NAME_LEN 20 #define MAX_NUM_LEN 10 #define MAX_SCORE_LEN 5 #define MAX_STUDENT_NUM 100 typedef struct student { char name[MAX_NAME_LEN]; char num[MAX_NUM_LEN]; char score[MAX_SCORE_LEN]; } Student; Student students[MAX_STUDENT_NUM]; int student_num = 0; void add_student() { if (student_num >= MAX_STUDENT_NUM) { printf("学生信息已满,无法添加!\n"); return; } printf("请输入学生姓名:"); scanf("%s", students[student_num].name); printf("请输入学生学号:"); scanf("%s", students[student_num].num); printf("请输入学生成绩:"); scanf("%s", students[student_num].score); student_num++; printf("添加成功!\n"); } void delete_student() { char num[MAX_NUM_LEN]; printf("请输入要删除的学生学号:"); scanf("%s", num); int i; for (i = 0; i < student_num; i++) { if (strcmp(students[i].num, num) == 0) { int j; for (j = i; j < student_num - 1; j++) { strcpy(students[j].name, students[j + 1].name); strcpy(students[j].num, students[j + 1].num); strcpy(students[j].score, students[j + 1].score); } student_num--; printf("删除成功!\n"); return; } } printf("未找到该学生!\n"); } void modify_student() { char num[MAX_NUM_LEN]; printf("请输入要修改的学生学号:"); scanf("%s", num); int i; for (i = 0; i < student_num; i++) { if (strcmp(students[i].num, num) == 0) { printf("请输入学生姓名:"); scanf("%s", students[i].name); printf("请输入学生成绩:"); scanf("%s", students[i].score); printf("修改成功!\n"); return; } } printf("未找到该学生!\n"); } void query_student() { char name[MAX_NAME_LEN]; char num[MAX_NUM_LEN]; printf("请输入要查询的学生姓名或学号:"); scanf("%s", name); int i; for (i = 0; i < student_num; i++) { if (strcmp(students[i].name, name) == 0 || strcmp(students[i].num, name) == 0) { printf("学生姓名:%s\n", students[i].name); printf("学生学号:%s\n", students[i].num); printf("学生成绩:%s\n", students[i].score); return; } } printf("未找到该学生!\n"); } void sort_student() { char type; printf("请选择排序方式(n-按学号排序,s-按成绩排序):"); scanf(" %c", &type); int i, j; for (i = 0; i < student_num - 1; i++) { for (j = 0; j < student_num - i - 1; j++) { if ((type == 'n' && strcmp(students[j].num, students[j + 1].num) > 0) || (type == 's' && strcmp(students[j].score, students[j + 1].score) > 0)) { Student temp = students[j]; students[j] = students[j + 1]; students[j + 1] = temp; } } } printf("排序成功!\n"); } void display_student() { int i; for (i = 0; i < student_num; i++) { printf("学生姓名:%s\n", students[i].name); printf("学生学号:%s\n", students[i].num); printf("学生成绩:%s\n", students[i].score); } } void open_file() { FILE *fp = fopen("students.txt", "r"); if (fp == NULL) { printf("文件打开失败!\n"); return; } student_num = 0; while (fscanf(fp, "%s %s %s", students[student_num].name, students[student_num].num, students[student_num].score) != EOF) { student_num++; } fclose(fp); printf("文件打开成功!\n"); } void save_file() { FILE *fp = fopen("students.txt", "w"); if (fp == NULL) { printf("文件打开失败!\n"); return; } int i; for (i = 0; i < student_num; i++) { fprintf(fp, "%s %s %s\n", students[i].name, students[i].num, students[i].score); } fclose(fp); printf("保存成功!\n"); } void save_sorted_file() { char type; printf("请选择排序方式(n-按学号排序,s-按成绩排序):"); scanf(" %c", &type); FILE *fp = fopen("sorted_students.txt", "w"); if (fp == NULL) { printf("文件打开失败!\n"); return; } int i, j; for (i = 0; i < student_num - 1; i++) { for (j = 0; j < student_num - i - 1; j++) { if ((type == 'n' && strcmp(students[j].num, students[j + 1].num) > 0) || (type == 's' && strcmp(students[j].score, students[j + 1].score) > 0)) { Student temp = students[j]; students[j] = students[j + 1]; students[j + 1] = temp; } } } for (i = 0; i < student_num; i++) { fprintf(fp, "%s %s %s\n", students[i].name, students[i].num, students[i].score); } fclose(fp); printf("保存成功!\n"); } int main() { int choice; while (1) { printf("请选择操作:\n"); printf("1. 增加记录\n"); printf("2. 删除记录\n"); printf("3. 修改记录\n"); printf("4. 查询记录\n"); printf("5. 排序记录\n"); printf("6. 显示记录\n"); printf("7. 打开文件\n"); printf("8. 保存文件\n"); printf("9. 保存排序后的文件\n"); printf("0. 退出程序\n"); printf("请输入操作编号:"); scanf("%d", &choice); switch (choice) { case 1: add_student(); break; case 2: delete_student(); break; case 3: modify_student(); break; case 4: query_student(); break; case 5: sort_student(); break; case 6: display_student(); break; case 7: open_file(); break; case 8: save_file(); break; case 9: save_sorted_file(); break; case 0: return 0; default: printf("无效操作!\n"); break; } } return 0; } ```

相关推荐

最新推荐

recommend-type

VC6.0实现读取Excel数据的方法

主要介绍了VC6.0实现读取Excel数据的方法,非常实用的功能,需要的朋友可以参考下
recommend-type

vc6.0使用教程详解

新手、高手都适用的VC6.0使用教程。你首先要打开VC6.0界面,一般用得较多的是Win32控制台应用程序……
recommend-type

VC6.0 MFC MSComm串口控件详解

此文档详细介绍了VC6.0 MFC下MSComm串口控件的属性,对于用MFC写串口助手之类的程序有一定帮助
recommend-type

C语言课程设计报告学生管理信息系统设计

设计该程序是为了实现更简洁的学生信息管理,满足管理学生学号、姓名和成绩等信息的要求。 系统具体功能如下: (1)输入记录 ——输入的记录包括:学生学生证号、姓名、成绩; (2)显示记录 ——显示所有以上输入...
recommend-type

VC6.0为对话框添加菜单

在VC中为对话框添加菜单,初学者可以看看,高手不用浪费时间了,很简单的东西,记下来放到这里做笔记。 一个Word文档,本来想贴在空间里,结果图片不能直接复制,不想再挨个截图,放在这里。
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向

![:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向](https://img-blog.csdnimg.cn/7e3d12895feb4651b9748135c91e0f1a.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5rKJ6YaJ77yM5LqO6aOO5Lit,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. YOLO目标检测算法简介 YOLO(You Only Look Once)是一种
recommend-type

def ObjFun(x,y,beta): # 目标函数 """ Logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: loss value """ n = x.shape[0] p = x.shape[1] pred = 1 / (1 + np.exp(-np.dot(x, beta))) pred = np.clip(pred, 1e-15, 1 - 1e-15) # 将预测值限制在一个很小的区间内 ObjVal = -np.sum(y * np.log(pred) + (1 - y) * np.log(1 - pred)) / n return ObjVal

好的,根据上面的目标函数,我们可以推导出其对应的梯度向量函数,如下所示: def gradient(x, y, beta): """ Compute gradient of the logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: gradient vector """ n = x.shape[0] pred = 1 /
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。