【c++/c】C语言“小小计算器”扩展功能,文件的读取和写入【期末大作业】

简介: 学生成绩排序” 定义学生结构体数组,长度为10,依次输入这十个学生的学号、姓名、成绩,利用冒泡排序,对这10个学生排序,从小到大输出这10个学生的信息,然后输出10个学生的总成绩和平时成绩

实验1、“小小计算器”扩展功能实现(1)

扩充小小计算器功能:
<1> “22 学生成绩排序”
定义学生结构体数组,长度为10,依次输入这十个学生的学号、姓名、成绩,利用冒泡排序,对这10个学生排序,从小到大输出这10个学生的信息,然后输出10个学生的总成绩和平时成绩

代码整合:

#include <iostream>
#include <stdio.h>
#include <stdlib.h>
using namespace std;


int main() {
const int n=10;
struct student //定义结构体变量
{
    string name;
 
    int num;
 
    double score;
 
};
    struct student student1[n];
    struct student student2;
    int i,j;
 
    for(i=0;i<n;i++)
    {
        cout<<"请输入第"<<i+1<<"个学生的信息:";
        cin>>student1[i].num
           >>student1[i].name
           >>student1[i].score;
    }
 
    double sum=0;
    double average;
 
    //各学生的平均成绩
    for(i=0;i<n;i++)
    {
        
        sum=sum+student1[i].score;
        
        average=sum/3;

    }
    // 冒泡排序
    for(int j=0;j<n;j++){
        for(i=0;i<n-j-1;i++){
                if(student1[i].score>student1[i+1].score){
                        student2 = student1[i];
                        student1[i] = student1[i+1];
                        student1[i+1] = student2;
               }
        }
    
    } 
    //打印出各学生的信息
    cout<<"输出各学生信息:"<<endl;
 
    for(i=0;i<n;i++)
    {
        cout<<student1[i].num<<"  "
 
           <<student1[i].name<<"  "
 
           <<student1[i].score<<"  "
           
           <<endl;
    }

 
    cout<<"总成绩:"<<sum<<"  "
        <<"平均成绩"<<average
        <<endl;
 
 
 
    return 0;
}

结果

在这里插入图片描述

实验2、“小小计算器”扩展功能实现(2)

扩充小小计算器功能:
<1> “23 学生成绩普涨10分”
d盘根目录下存在一个文本文件my.txt,里面存放了10个学生的成绩,一行一个成绩,从文件中读取学生的成绩,每个成绩都加10分后,保存到原文件中。
提示:

 注意d:\my.txt在fopen中如何表示;—> “d:\my.txt”  文件打开方式 —> r+
 从文件中读取数据,直到文件结束,如何判断文件结束—> feof()
 将增加10后的数据保存到原文件时,要保证从文件头开始,如何使文件指针回到文件头—> rewind()
 在写数据时,一定要避免在最后一个数据写完后,再写一个回车,否则下次在操作时可能出错。

代码

#include <stdio.h>
#include <stdlib.h>
#define N 10
struct Student
{
int num;
char name[10];
double score;
};
int main()
{
FILE *fp;
struct Student stu[N];
int i;
fp=fopen("d:\\my.txt","r+");
if(fp==NULL)
{
    
printf ("文件打开失败!\n");
exit(1);
}
printf("打开读取文件,内容是:\n");
i=0;
while(1)
{
if(feof(fp)) break;
fscanf(fp,"%d\t%s\t%lf\n",&stu[i].num,stu[i].name,&stu[i].score);
printf("%d\t%s\t%.2f\n",stu[i].num,stu[i].name,stu[i].score);
i++;
}
rewind(fp);
for(i=0;i<N-1;i++)
{
fprintf(fp,"%d\t%s\t%.2f\n",stu[i].num,stu[i].name,stu[i].score+10);
}
fprintf(fp,"%d\t%s\t%.2f",stu[N-1].num,stu[N-1].name,stu[N-1].score+10);
fclose(fp);
return 0;
}

结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

解决问题:中文乱码

可以看到,虽然读取成功但是出现了中文乱码😫😫,根据以往经验,应该是编码方式问题!
在这里插入图片描述
可以看到编码为UTF-8
将其改为ANSI
在这里插入图片描述
在运行一下,看看结果
在这里插入图片描述
读取没问题,看看写入
在这里插入图片描述
完美解决🤗🤗!

目录
相关文章
|
1月前
|
存储 C++ UED
【实战指南】4步实现C++插件化编程,轻松实现功能定制与扩展
本文介绍了如何通过四步实现C++插件化编程,实现功能定制与扩展。主要内容包括引言、概述、需求分析、设计方案、详细设计、验证和总结。通过动态加载功能模块,实现软件的高度灵活性和可扩展性,支持快速定制和市场变化响应。具体步骤涉及配置文件构建、模块编译、动态库入口实现和主程序加载。验证部分展示了模块加载成功的日志和配置信息。总结中强调了插件化编程的优势及其在多个方面的应用。
227 64
|
25天前
|
存储 编译器 C语言
如何在 C 语言中判断文件缓冲区是否需要刷新?
在C语言中,可以通过检查文件流的内部状态或使用`fflush`函数尝试刷新缓冲区来判断文件缓冲区是否需要刷新。通常,当缓冲区满、遇到换行符或显式调用`fflush`时,缓冲区会自动刷新。
|
25天前
|
存储 编译器 C语言
C语言:文件缓冲区刷新方式有几种
C语言中文件缓冲区的刷新方式主要包括三种:自动刷新(如遇到换行符或缓冲区满)、显式调用 fflush() 函数强制刷新、以及关闭文件时自动刷新。这些方法确保数据及时写入文件。
|
1月前
|
C语言
大学生期末C语言实验(学生成绩和鞍点)
大学生期末C语言实验(学生成绩和鞍点)
148 0
大学生期末C语言实验(学生成绩和鞍点)
|
1月前
|
C语言
【C语言】探索文件读写函数的全貌(三)
【C语言】探索文件读写函数的全貌
|
1月前
|
存储 C语言
【C语言】探索文件读写函数的全貌(二)
【C语言】探索文件读写函数的全貌
|
1月前
|
编译器 C语言
初识C语言:扩展世界观,选择语句之行
初识C语言:扩展世界观,选择语句之行
|
1月前
|
C语言
【C语言】探索文件读写函数的全貌(一)
【C语言】探索文件读写函数的全貌
|
1月前
|
存储 文件存储 C语言
【C语言】深入了解文件:简明指南
【C语言】深入了解文件:简明指南
|
2月前
|
网络协议 C语言
C语言 网络编程(十三)并发的TCP服务端-以进程完成功能
这段代码实现了一个基于TCP协议的多进程并发服务端和客户端程序。服务端通过创建子进程来处理多个客户端连接,解决了粘包问题,并支持不定长数据传输。客户端则循环发送数据并接收服务端回传的信息,同样处理了粘包问题。程序通过自定义的数据长度前缀确保了数据的完整性和准确性。