#include <stdio.h> #define MAX 100 // 最大学生数量 struct Student { char czName[20]; // 学生姓名 char czNumber[20]; // 学生学号 char guli[8]; }; int main() { FILE* fp = fopen("students.txt", "r+"); if (fp == NULL) { printf("Failed to open file!\n"); exit(0); } struct Student Student[MAX]; // 定义结构体数组 int i=0; int nCount=0; int m,j,k; struct Student a; while (fscanf(fp,"%s %s %s", Student[i].czName,Student[i].czNumber,Student[i].guli) ==3) { nCount++; // i++; } fclose(fp); // 打印学生信息 for (i = 0; i < nCount; i++) { printf("%s %s %s\n", Student[i].czName, Student[i].czNumber, Student[i].guli); } printf("Sort\n"); printf("1,Sort by name\n"); printf("2,Sort by Number\n"); printf("3,Sort by room\n"); scanf("%d",&m); switch(m) { case 1: for(j=0;j<nCount-1;j++) { for(k=0;k<nCount-i-1;k++) { if(strcmp(Student[j].czName, Student[j+1].czName) > 0) { a=Student[k]; Student[k+1]=Student[k]; Student[k]=a; } } } for (i = 0; i < nCount; i++) { printf("%s %s %s\n", Student[i].czName, Student[i].czNumber, Student[i].guli); }break; case 2: for(j=0;j<nCount-1;j++) { for(k=0;k<nCount-i-1;k++) { if(strcmp(Student[j].czNumber, Student[j+1].czNumber) > 0) { a=Student[k]; Student[k+1]=Student[k]; Student[k]=a; } } } for (i = 0; i < nCount; i++) { printf("%s %s %s\n", Student[i].czName, Student[i].czNumber, Student[i].guli); }break; case 3: for(j=0;j<nCount-1;j++) { for(k=0;k<nCount-i-1;k++) { if(strcmp(Student[j].guli, Student[j+1].guli) > 0) { a=Student[k]; Student[k+1]=Student[k]; Student[k]=a; } } } for (i = 0; i < nCount; i++) { printf("%s %s %s\n", Student[i].czName, Student[i].czNumber, Student[i].guli); }break; default: break; } return 0; }为什么没显示排序好的信息
时间: 2024-03-02 22:52:29 浏览: 53
根据您提供的代码,我看到您进行了排序操作,但是在排序后并没有重新将排序后的结果写回到文件中,因此在打印学生信息时,仍然是读取的原始文件内容,没有进行排序后的更新。您需要在排序完成后,将排序后的结果写回到文件中,以便下次读取时能够获取到排序后的结果。您可以使用类似以下的代码将排序后的结果写回到文件中:
```c
fp = fopen("students.txt", "w");
if (fp == NULL) {
printf("Failed to open file!\n");
exit(0);
}
for (i = 0; i < nCount; i++) {
fprintf(fp, "%s %s %s\n", Student[i].czName, Student[i].czNumber, Student[i].guli);
}
fclose(fp);
```
这样,在下次读取文件时,您就可以得到排序后的结果了。
相关问题
#include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_SIZE 100 // 学生信息结构体 typedef struct { char num[10]; // 学号 char name[10]; // 姓名 char clas[10]; // 班级 char sex[10]; // 性别 float score; // 成绩 } Student; // 学生信息数组 Student studentList[MAX_SIZE]; int size = 0; 帮我添加一个可以查询学生成绩最大值和最小值的分函数代码
可以添加以下代码来实现查询学生成绩最大值和最小值的函数:
```c
// 查询学生成绩最大值和最小值
void findMinMaxScore() {
float maxScore = 0, minScore = 100;
for (int i = 0; i < size; i++) {
if (studentList[i].score > maxScore) {
maxScore = studentList[i].score;
}
if (studentList[i].score < minScore) {
minScore = studentList[i].score;
}
}
printf("成绩最高的学生信息:\n");
for (int i = 0; i < size; i++) {
if (studentList[i].score == maxScore) {
printf("学号:%s 姓名:%s 班级:%s 性别:%s 成绩:%.2f\n",
studentList[i].num, studentList[i].name,
studentList[i].clas, studentList[i].sex,
studentList[i].score);
}
}
printf("成绩最低的学生信息:\n");
for (int i = 0; i < size; i++) {
if (studentList[i].score == minScore) {
printf("学号:%s 姓名:%s 班级:%s 性别:%s 成绩:%.2f\n",
studentList[i].num, studentList[i].name,
studentList[i].clas, studentList[i].sex,
studentList[i].score);
}
}
}
```
在主函数中,可以通过调用该函数来查询学生成绩最大值和最小值:
```c
int main() {
// 添加学生信息
// ...
// 查询学生成绩最大值和最小值
findMinMaxScore();
return 0;
}
```
#include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_STUDENTS 100 // 最多支持100个学生 struct date{ int year; int month; int day; }; typedef struct { int num; // 学号 char name[20]; // 姓名 char sex[5]; // 性别 struct date birthday; // 出生日期 int score[3]; // 三门功课成绩 int total; // 总分 double average; // 平均分 } student; student students[MAX_STUDENTS]; // 学生数组 int num_students = 0; // 学生数量
这段代码定义了一个名为student的结构体,其中包含了学生的学号、姓名、性别、出生日期、三门功课成绩、总分和平均分等信息。同时还定义了一个名为date的结构体,用来表示学生的出生日期。
另外还定义了一个名为students的数组来存储学生信息,数组的长度为MAX_STUDENTS,即最多支持100个学生。还定义了一个变量num_students用来记录当前学生数量。
这段代码的作用是定义了一些数据结构和变量,用来存储和处理学生信息。具体的操作需要在其他代码中实现。
阅读全文