fread 读入优化

先做个比较

iostream:最慢
stdio,解绑的iostream:慢
(i<<1)+(i<<3)优化的读入:快

但有时还不够

这时就只能使用fread!

#include <stdio.h>
char Buffer[65536];
int Size,Pos;
bool Empty;
bool GetChar(char& c) {
    if(Empty) {
        c=0;
        return false;
    } else if(Size^Pos) {
        c=Buffer[Pos++];
        return true;
    } else {
        Size=fread(Buffer,1,65536,stdin);
        if(Size) {
            Pos=1;
            c=Buffer[0];
            return true;
        } else {
            Empty=true;
            c=0;
            return false;
        }
    }
}

把这个与一般优化合起来,速度可以优化许多.

另,可以尝试在函数前加

__attribute__((optimize("Ofast")))

不过考试时最好别加…

注意,若开了这个,最好不用(i<<1)+(i<<3)和一些小优化,会反而变慢.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了将二进制文件读入链表,你可以按照以下步骤进行操作: 1. 首先,你需要定义一个结构体来表示学生的信息,包括学号、姓名、性别、年龄和成绩等字段。 2. 然后,你需要创建一个链表结构,用来存储学生的信息。链表的每个节点都包含一个学生的结构体对象和指向下一个节点的指针。 3. 接下来,你需要打开二进制文件,以读取其中的数据。你可以使用C语言中的fopen函数打开文件,使用fread函数读取文件中的数据,并使用fclose函数关闭文件。 4. 在读取文件数据之前,你需要判断文件是否存在,如果不存在则创建一个空链表。如果文件已经存在,则需要将文件中的数据读取到链表中。 5. 当你读取到文件中的学生信息后,需要将其插入到链表中的合适位置,按照总成绩从大到小的顺序进行插入。你可以通过比较当前学生的成绩与链表中已有学生的成绩来确定插入位置。 6. 最后,你可以选择是否继续从用户输入中读取更多的学生信息,如果用户选择继续,则重复步骤3-5,直到用户选择退出。 7. 当用户选择退出后,你可以将链表中的数据重新写入到二进制文件中。你可以使用fwrite函数将链表中的数据按照总成绩从大到小的顺序写入到文件中。 请注意,这只是一个概述,并不包含具体的代码实现。实际的代码可能需要进一步的细节处理和错误处理。同时,你还可以根据具体需求对代码进行修改和优化。希望对你有所帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [实验十 学生成绩管理(二进制文件读写)byHNU信息院2020小毕](https://blog.csdn.net/jiajia1as/article/details/111879722)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [高级java开发集合问题](https://download.csdn.net/download/tgh5330992/88227020)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值