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; 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); }用swtich进行排序
时间: 2024-03-02 21:51:38 浏览: 27
好的,你的问题是如何使用 switch 语句对学生信息进行排序?
首先,要确定按照哪个字段进行排序,例如按照学生学号进行排序。然后,可以使用冒泡排序算法对学生信息进行排序。
冒泡排序算法是一种简单的排序算法,它的基本思想是通过相邻元素之间的比较和交换来将较大的元素向数组的一端移动,从而实现排序。
以下是使用 switch 和冒泡排序算法对学生信息按照学号进行排序的示例代码:
```c
#include <stdio.h>
#include <string.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;
while (fscanf(fp, "%s %s %s", Student[i].czName, Student[i].czNumber, Student[i].guli) == 3) {
nCount++;
i++;
}
fclose(fp);
// 按照学号排序
int j, k;
struct Student temp;
for (j = 0; j < nCount - 1; j++) {
for (k = 0; k < nCount - j - 1; k++) {
// 判断当前两个学生学号的大小关系
switch (strcmp(Student[k].czNumber, Student[k + 1].czNumber)) {
case 1: // 前一个学号大于后一个学号,需要交换
temp = Student[k];
Student[k] = Student[k + 1];
Student[k + 1] = temp;
break;
case 0: // 两个学号相等,不需要交换
case -1: // 前一个学号小于后一个学号,不需要交换
break;
}
}
}
// 打印学生信息
for (i = 0; i < nCount; i++) {
printf("%s %s %s\n", Student[i].czName, Student[i].czNumber, Student[i].guli);
}
return 0;
}
```
在上面的代码中,我们使用了 strcmp 函数来比较两个学号的大小关系,如果前一个学号大于后一个学号,则需要交换这两个学生的位置。最后,使用 for 循环遍历排序后的学生信息并打印出来。
注意,为了简化代码,上面的示例中只实现了按照学号进行排序,如果需要按照其他字段进行排序,可以类似地进行修改。