YTU 2924: 文件操作--二进制文件读入
2016-04-06 16:12
483 查看
2924: 文件操作--二进制文件读入
时间限制: 1 Sec 内存限制: 128 MB提交: 58 解决: 20
题目描述
现有100名学生的姓名(name)、学号(num)、英语(English)、数学(Math)、语文(Chinese)成绩存储在一个二进制文件student.dic中(姓名用char[20],学号和各科成绩用int存储),现要求将指定行数的学生信息输出,每条信息占一行。前5行学生信息为:
akdh 13773 84 83 66
fjka 30257 15 14 88
sfhklas 61281 87 8 31
hfu 38635 55 50 60
iwehfk 92803 54 6 77
输入
要输出行号的整数序列,以0作为结束标志。
输出
输出学生信息,每个学生占一行
样例输入
1 3 5 0
样例输出
akdh 13773 84 83 66 sfhklas 61281 87 8 31 iwehfk 92803 54 6 77
迷失在幽谷中的鸟儿,独自飞翔在这偌大的天地间,却不知自己该飞往何方……
#include <iostream> #include <fstream> #include <algorithm> #include <ctime> #include <stdlib.h> using namespace std; struct student { char name[20]; int num,English,Math,Chinese; }; int main() { ifstream infile("student.dic",ios::in|ios::binary); if(!infile) { cerr<<"open error!"<<endl; return -1; } int n; student stu; while((cin>>n)&&n!=0) { infile.seekg((n-1)*sizeof(stu),ios::beg); infile.read((char *)&stu,sizeof(stu)); cout<<stu.name<<" "<<stu.num<<" "<<stu.English<<" "<<stu.Math<<" "<<stu.Chinese<<endl; } infile.close(); return 0; }
相关文章推荐
- 关于GPL协议的理解(开源与商用、免费与收费的理解)
- 链表归并排序
- 机器学习基础(四十三)—— kd 树( k 近邻法的实现)
- 循环列表解决n个人首位相连报数问题
- POJ 3254 Corn Fields【状压dp】
- cpufreq 五种模式
- 如何建立sitemap网站地图(google)
- Android小项目:计算器
- mysql 5.6.17 x64 安装
- ThinkPHP 框架开发 零基础开发 网站商城 步骤 (1)
- Swift NavigationController的使用
- 极光推送-感受下极光推送的效果
- 功能测试的测试工作流程
- 在Eclipse中使用JUnit4进行单元测试(初级篇)
- R连接mysql以及一些操作
- php的config.inc.php
- Caffe学习系列(17):模型各层特征和过滤器可视化
- 三角形
- C++语言的表达式模板:表达式模板的入门性介绍
- 购买李宁老师视频课程,赶快来领优惠劵啊,数量有限,先到先得。