#include<stdio.h> #include<string.h> typedef struct nodelink { long num; char name[20]; int Chinese; int Math; int English; float aver; }stu; int main() { stu b[10]; FILE *pf; pf=fopen("stud.txt","a"); stu a[10]; for(int i=0;i<3;i++) { printf("请输入第%d个学生的学号,姓名,语文成绩,数学成绩,英语成绩:\n", i + 1); scanf("%ld", &a[i].num); getchar(); fgets(a[i].name, 20, stdin); a[i].name[strlen(a[i].name) - 1] = '\0'; scanf("%d%d%d", &a[i].Chinese, &a[i].Math, &a[i].English); a[i].aver=(a[i].Chinese+a[i].Math+a[i].English)/3.0; fprintf(pf,"%ld\t%s\t%d\t%d\t%d\t%.1f\n",a[i].num,a[i].name,a[i].Chinese,a[i].Math,a[i].English,a[i].aver); } for(int i=0;i<3;i++) { fscanf(pf,"%ld\t%s\t%d\t%d\t%d\t%.1f\n",&b[i].num,b[i].name,&b[i].Chinese,&b[i].Math,&b[i].English,&b[i].aver); printf("%ld\t%s\t%d\t%d\t%d\t%.1f\n",b[i].num,b[i].name,b[i].Chinese,b[i].Math,b[i].English,b[i].aver); } fclose(pf); FILE *pf1; pf1=fopen("studsort.txt","a"); stu k; for(int i=0;i<3;i++) for(int j=i;j<3;j++) { if(b[i].aver>b[j].aver) { k=b[i]; b[i]=b[j]; b[j]=k; } } for(int i=0;i<3;i++) { fprintf(pf1,"%ld\t%s\t%d\t%d\t%d\t%.1f\n",b[i].num,b[i].name,b[i].Chinese,b[i].Math,b[i].English,b[i].aver); } fclose(pf1); return 0; }
时间: 2023-12-06 10:41:36 浏览: 24
这是一个 C 语言程序,实现了学生信息的输入、输出和排序,并将结果保存到文件中。具体实现步骤如下:
1. 定义一个结构体类型 stu,包含学号(num)、姓名(name)、语文成绩(Chinese)、数学成绩(Math)、英语成绩(English)和平均分(aver)。
2. 在主函数中定义两个 stu 类型的数组 a 和 b,分别用于存储输入的学生信息和排序后的学生信息。
3. 打开一个名为 stud.txt 的文件,并使用 fprintf 函数将输入的学生信息写入文件中。
4. 使用 fscanf 函数从文件中读取学生信息,并将其存储到数组 b 中,然后使用 printf 函数输出数组 b 中的学生信息。
5. 打开一个名为 studsort.txt 的文件,并使用 fprintf 函数将排序后的学生信息写入文件中。
6. 使用冒泡排序算法对数组 b 中的学生信息进行排序。
7. 使用 fprintf 函数将排序后的学生信息写入文件 studsort.txt 中。
8. 关闭文件并结束程序。
需要注意的是,程序中的文件操作都需要进行错误处理,以确保文件打开和关闭的正常进行。另外,本程序只能处理 3 个学生的信息,如果需要处理更多的学生信息,需要相应地修改程序。
相关问题
#include<stdio.h>#include<stdlib.h>#include<string.h>
在C语言中,`#include<stdio.h>`、`#include<stdlib.h>`和`#include<string.h>`分别包含了输入/输出、内存管理以及字符串处理相关的库。这里给你演示如何使用这些头文件中的函数:
1. **输入/输出(stdio.h)**:
```c
#include<stdio.h>
int main() {
printf("Hello, World!\n"); // 使用printf输出字符串
scanf("%s", "Enter your name: "); // 使用scanf从用户那里读取输入
return 0;
}
```
2. **内存管理(stdlib.h)**:
```c
#include<stdlib.h>
int *createArray(int size) {
int *array = malloc(size * sizeof(int)); // 分配动态内存
return array;
}
void freeMemory(int *array, int size) {
free(array); // 释放已分配的内存
}
```
3. **字符串处理(string.h)**:
```c
#include<string.h>
char* copyString(const char* src) {
char* dest = (char*)malloc(strlen(src) + 1); // 动态分配内存复制字符串
strcpy(dest, src);
return dest;
}
```
注意,C语言的标准库函数可能需要链接到适当的库,如`-lstdc++` 或 `-lm`,具体取决于编译器设置。
#include <stdio.h> #include <malloc.h> typedef char ElemType; typedef struct LNode
#include <stdio.h> 和 #include <malloc.h> 是 C 语言中的头文件,前者用于输入输出,后者用于内存动态分配和释放。
typedef char ElemType; 定义了一个名为 ElemType 的数据类型,实际上是 char 类型。
typedef struct LNode 定义了一个名为 LNode 的结构体类型。
该结构体类型中可以包含多个成员变量,具体定义方式如下:
typedef struct LNode {
int data;
struct LNode* next;
} LNode;
这里定义了一个 LNode 结构体类型,其中包含两个成员变量:data 和 next。data 是一个整型变量,next 是一个指向 LNode 类型的指针变量。这种结构体类型通常用于链表的实现。
相关推荐
![text/x-c](https://img-home.csdnimg.cn/images/20210720083646.png)
![application/msword](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)