linux下基于c语言的学生学籍管理系统,学生的学籍信息包括:学号、姓名、性别、年龄、专业、电话。 实现学生学籍信息的插入,可分别输入学生的相关信息。 能按学生姓名查找和删除单个学生信息。 能够一次性显示所有学生的学籍信息。 使用文件操作函数实现数据的写入和读出,文件名保存为stu.txt。
时间: 2023-04-30 18:06:40 浏览: 117
这是一道关于Linux下基于C语言的学生学籍管理系统的问题,包含学号、姓名、性别、年龄、专业、电话等学生信息。实现学生学籍信息的插入,可以逐个输入学生的相关信息。能够按学生姓名查找和删除单个学生信息。能够一次性显示所有学生的学籍信息。使用文件操作函数实现数据的写入和读出,文件名保存为stu.txt。
相关问题
c语言编写链表结构的学籍管理系统,学生学籍库包括:学号、姓名、性别、出生年月、第二学期大学英语和数据结构的成绩。系统菜单(即先输出提示信息序号1、2、3…,分别实现什么功能,输入序号后,调用相应的功能函数)。学生信息录入功能。学生信息删除功能。显示学生信息。学生信息查找。依据总分成绩对学生信息进行排序。
好的,我理解你的问题是关于C语言编写链表结构的学籍管理系统的实现。以下是一个可能的实现,其中包括菜单选项和相应的功能函数。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 结构体定义
typedef struct student {
char id[20]; // 学号
char name[20]; // 姓名
char gender[10]; // 性别
char birth[20]; // 出生年月
float eng_score; // 英语成绩
float ds_score; // 数据结构成绩
float total_score; // 总分
struct student* next;
} student_t;
// 学生信息录入
void add_student(student_t** head) {
student_t* new_node = (student_t*) malloc(sizeof(student_t));
printf("请输入学号:");
scanf("%s", new_node->id);
printf("请输入姓名:");
scanf("%s", new_node->name);
printf("请输入性别:");
scanf("%s", new_node->gender);
printf("请输入出生年月:");
scanf("%s", new_node->birth);
printf("请输入第二学期大学英语成绩:");
scanf("%f", &(new_node->eng_score));
printf("请输入第二学期数据结构成绩:");
scanf("%f", &(new_node->ds_score));
new_node->total_score = new_node->eng_score + new_node->ds_score;
new_node->next = NULL;
if (*head == NULL) {
*head = new_node;
} else {
student_t* cur = *head;
while (cur->next != NULL) {
cur = cur->next;
}
cur->next = new_node;
}
printf("学生信息录入成功!\n");
}
// 学生信息删除
void delete_student(student_t** head) {
char id[20];
printf("请输入要删除的学生学号:");
scanf("%s", id);
if (*head == NULL) {
printf("学生信息库为空,无法删除!\n");
} else {
student_t* cur = *head;
student_t* prev = NULL;
while (cur != NULL) {
if (strcmp(cur->id, id) == 0) {
if (prev == NULL) {
*head = cur->next;
} else {
prev->next = cur->next;
}
free(cur);
printf("学生信息删除成功!\n");
return;
} else {
prev = cur;
cur = cur->next;
}
}
printf("未找到学号为%s的学生信息!\n", id);
}
}
// 显示学生信息
void display_students(student_t* head) {
if (head == NULL) {
printf("学生信息库为空!\n");
} else {
printf("学号\t姓名\t性别\t出生年月\t英语成绩\t数据结构成绩\t总分\n");
student_t* cur = head;
while (cur != NULL) {
printf("%s\t%s\t%s\t%s\t%.2f\t%.2f\t%.2f\n", cur->id, cur->name, cur->gender, cur->birth, cur->eng_score, cur->ds_score, cur->total_score);
cur = cur->next;
}
}
}
// 学生信息查找
void search_student(student_t* head) {
char id[20];
printf("请输入要查找的学生学号:");
scanf("%s", id);
if (head == NULL) {
printf("学生信息库为空,无法查找!\n");
} else {
student_t* cur = head;
while (cur != NULL) {
if (strcmp(cur->id, id) == 0) {
printf("学号\t姓名\t性别\t出生年月\t英语成绩\t数据结构成绩\t总分\n");
printf("%s\t%s\t%s\t%s\t%.2f\t%.2f\t%.2f\n", cur->id, cur->name, cur->gender, cur->birth, cur->eng_score, cur->ds_score, cur->total_score);
return;
} else {
cur = cur->next;
}
}
printf("未找到学号为%s的学生信息!\n", id);
}
}
// 依据总分成绩对学生信息进行排序
void sort_students(student_t** head) {
if (*head == NULL) {
printf("学生信息库为空,无法排序!\n");
} else {
int count = 0;
student_t* cur = *head;
while (cur != NULL) {
count++;
cur = cur->next;
}
// 冒泡排序
for (int i = 0; i < count - 1; i++) {
student_t* prev = NULL;
student_t* cur = *head;
for (int j = 0; j < count - i - 1; j++) {
if (cur->total_score < cur->next->total_score) {
if (prev == NULL) {
*head = cur->next;
} else {
prev->next = cur->next;
}
cur->next = cur->next->next;
prev = cur->next;
cur->next->next = cur;
} else {
prev = cur;
cur = cur->next;
}
}
}
printf("学号\t姓名\t性别\t出生年月\t英语成绩\t数据结构成绩\t总分\n");
student_t* cur = *head;
while (cur != NULL) {
printf("%s\t%s\t%s\t%s\t%.2f\t%.2f\t%.2f\n", cur->id, cur->name, cur->gender, cur->birth, cur->eng_score, cur->ds_score, cur->total_score);
cur = cur->next;
}
}
}
// 主函数
int main() {
student_t* head = NULL;
int choice;
do {
printf("\n学籍管理系统菜单\n");
printf("1. 学生信息录入\n");
printf("2. 学生信息删除\n");
printf("3. 显示学生信息\n");
printf("4. 学生信息查找\n");
printf("5. 依据总分成绩对学生信息进行排序\n");
printf("0. 退出\n");
printf("请输入功能序号:");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student(&head);
break;
case 2:
delete_student(&head);
break;
case 3:
display_students(head);
break;
case 4:
search_student(head);
break;
case 5:
sort_students(&head);
break;
case 0:
printf("退出系统,谢谢使用!\n");
break;
default:
printf("输入有误,请重新输入!\n");
break;
}
} while (choice != 0);
return 0;
}
```
这个程序使用了链表来存储学生信息,可以实现学生信息录入、删除、显示、查找和排序等功能。在主函数中,不断循环显示菜单选项,并根据用户的选择调用相应的功能函数。注意,在链表中删除和排序操作时,需要注意指针的指向和连接。
用c语言编译学籍管理系统,有10个学生,学生学籍库包括:学号、姓名、性别、出生年月、第二学期 大学英语和数据结构的成绩。1)系统菜单(即先输出提示信息序号1、2、3…,分别实现什么功能,输 入序号后,调用相应的功能函数)。 2)学生信息录入功能。 3)学生信息删除功能。 4)显示学生信息。 5)学生信息查找。 6)依据总分成绩对学生信息进行排序。
好的,以下是一个简单的用C语言编写的学籍管理系统的代码,实现了您提到的所有功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义学生结构体
typedef struct {
char id[11]; // 学号
char name[20]; // 姓名
char sex[5]; // 性别
char birth[12]; // 出生年月
float english; // 大学英语成绩
float data_structure; // 数据结构成绩
} Student;
// 学生学籍库
Student students[10];
// 学生数量,初始值为0
int count = 0;
// 系统菜单
void showMenu() {
printf("=====================\n");
printf("1. 学生信息录入\n");
printf("2. 学生信息删除\n");
printf("3. 显示学生信息\n");
printf("4. 学生信息查找\n");
printf("5. 依据总分成绩对学生信息进行排序\n");
printf("6. 退出系统\n");
printf("=====================\n");
}
// 学生信息录入功能
void addStudent() {
if (count == 10) {
printf("学生学籍库已满,无法继续添加!\n");
return;
}
printf("请输入学号:");
scanf("%s", students[count].id);
printf("请输入姓名:");
scanf("%s", students[count].name);
printf("请输入性别:");
scanf("%s", students[count].sex);
printf("请输入出生年月(格式:yyyy-mm-dd):");
scanf("%s", students[count].birth);
printf("请输入第二学期大学英语成绩:");
scanf("%f", &students[count].english);
printf("请输入第二学期数据结构成绩:");
scanf("%f", &students[count].data_structure);
count++;
printf("学生信息录入成功!\n");
}
// 学生信息删除功能
void deleteStudent() {
char id[11];
int i, j;
printf("请输入要删除的学生学号:");
scanf("%s", id);
for (i = 0; i < count; i++) {
if (strcmp(students[i].id, id) == 0) {
// 找到了要删除的学生
for (j = i; j < count - 1; j++) {
students[j] = students[j+1];
}
count--;
printf("学生信息删除成功!\n");
return;
}
}
printf("未找到该学生信息!\n");
}
// 显示学生信息
void showStudents() {
int i;
if (count == 0) {
printf("学生学籍库为空!\n");
return;
}
printf("学号\t姓名\t性别\t出生年月\t大学英语成绩\t数据结构成绩\n");
for (i = 0; i < count; i++) {
printf("%s\t%s\t%s\t%s\t%.2f\t\t%.2f\n", students[i].id, students[i].name, students[i].sex, students[i].birth, students[i].english, students[i].data_structure);
}
}
// 学生信息查找
void searchStudent() {
char id[11];
int i;
printf("请输入要查找的学生学号:");
scanf("%s", id);
for (i = 0; i < count; i++) {
if (strcmp(students[i].id, id) == 0) {
printf("学号\t姓名\t性别\t出生年月\t大学英语成绩\t数据结构成绩\n");
printf("%s\t%s\t%s\t%s\t%.2f\t\t%.2f\n", students[i].id, students[i].name, students[i].sex, students[i].birth, students[i].english, students[i].data_structure);
return;
}
}
printf("未找到该学生信息!\n");
}
// 依据总分成绩对学生信息进行排序
void sortStudents() {
int i, j;
Student temp;
if (count == 0) {
printf("学生学籍库为空!\n");
return;
}
// 冒泡排序
for (i = 0; i < count-1; i++) {
for (j = 0; j < count-i-1; j++) {
if ((students[j].english + students[j].data_structure) < (students[j+1].english + students[j+1].data_structure)) {
temp = students[j];
students[j] = students[j+1];
students[j+1] = temp;
}
}
}
printf("学号\t姓名\t性别\t出生年月\t大学英语成绩\t数据结构成绩\t总分\n");
for (i = 0; i < count; i++) {
printf("%s\t%s\t%s\t%s\t%.2f\t\t%.2f\t\t%.2f\n", students[i].id, students[i].name, students[i].sex, students[i].birth, students[i].english, students[i].data_structure, students[i].english + students[i].data_structure);
}
}
int main() {
int choice;
while (1) {
showMenu();
printf("请输入要执行的操作序号:");
scanf("%d", &choice);
switch (choice) {
case 1: addStudent(); break;
case 2: deleteStudent(); break;
case 3: showStudents(); break;
case 4: searchStudent(); break;
case 5: sortStudents(); break;
case 6: exit(0);
default: printf("无效的操作序号!\n");
}
}
return 0;
}
```
以上代码可能还有不足之处,需要您自己测试和完善。希望能够对您有所帮助!
阅读全文