文件操作练习。注意B题的读取不能用struct。
D和谐词汇的题,输入是若干字符串,不以空行结束. 所以 gets(line); while (line[0]){... gets(line);}就会导致时间超限,代码在等空行,但in数据没有。应改为while(gets(line))。
/*文件练习B题. 读取一个包含7类数据的二进制文件,找到指定部分内容,并正确解释输出。
思路分析:主体框架是读取二进制文件, while (fread(buffer, buffLen, 1, infile) > 0){...}
因为二进制文件的记录长度是固定的,所以可以计算每条记录的长度,使用fseek直接定位到指定段;
所以用fseek的话,实际只需要读一次就可以。
但是这道题的特殊之处在于,一条记录内是顺序包含7种类型数据,是分多次写入,因此带来的麻烦是
虽然每段内容结构相同,但不能用struct进行整块读取。
因为struct的成员之间有内存空隙;除非源文件本身是用struct格式写入才行。
因此,可以直接定位,但必须分别读取,写出的代码冗长,且容易在变量名和输出格式上出错。
经测试,struct {含7种变量和数组}的长度为200, 但实际7种变量和数组的总长要小一些.
因此,可以直接定位,但必须分别读取,写出的代码冗长,且容易在变量名和输出格式上出错。
一种办法是:按总长度整块读取到字节数组中,然后再逐个定义对应类型的指针,按间接访问就可格式化解释输出。
例: char buffer[LEN];
int i=0; printf("%c\n", buffer[i]); i++;
short * hdPtr=&buffer[i]; printf("%hd\n", *hdPtr); i+=sizeof(short);
*/
RunID | User | Nick Name | Problem ID | Result | Memory | Time | Language | Code Length | Submit Time |
102445 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1196KB | 10ms | C | 3156 bytes | 2023-05-04 23:49:16 | |
102358 | 2022211349 | 泰拉瑞亚糕手 | Accepted | 1072KB | 10ms | C | 1241 bytes | 2023-05-04 23:16:31 | |
102354 | 2022211349 | 泰拉瑞亚糕手 | Output Limit Exceed | 1072KB | 12ms | C | 1247 bytes | 2023-05-04 23:14:52 | |
102326 | 2022211349 | 泰拉瑞亚糕手 | *Accepted65033 | 1072KB | 11ms | C | 2022 bytes | 2023-05-04 22:57:39 | |
102323 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1196KB | 9ms | C | 1137 bytes | 2023-05-04 22:57:06 | |
102313 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1196KB | 11ms | C | 1136 bytes | 2023-05-04 22:49:02 | |
102311 | 2022211349 | 泰拉瑞亚糕手 | Runtime Error | 1196KB | 10ms | C | 1168 bytes | 2023-05-04 22:48:17 | |
102265 | 2022211349 | 泰拉瑞亚糕手 | Runtime Error | 1204KB | 9ms | C | 959 bytes | 2023-05-04 22:15:45 | |
102259 | 2022211349 | 泰拉瑞亚糕手 | Compile Error | 0KB | 0ms | C | 962 bytes | 2023-05-04 22:11:54 | |
102144 | 2022211349 | 泰拉瑞亚糕手 | Accepted | 1240KB | 11ms | C | 1094 bytes | 2023-05-04 20:58:00 | |
102091 | 2022211349 | 泰拉瑞亚糕手 | *Accepted68657 | 1240KB | 11ms | C | 1680 bytes | 2023-05-04 19:46:26 | |
102088 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1240KB | 10ms | C | 1321 bytes | 2023-05-04 19:43:23 | |
93697 | 2022211349 | 泰拉瑞亚糕手 | *Accepted64825 | 1200KB | 10ms | C | 3509 bytes | 2023-04-24 17:38:12 | |
93696 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 19ms | C | 4267 bytes | 2023-04-24 17:33:55 | |
93687 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 16ms | C | 4303 bytes | 2023-04-24 17:18:17 | |
93685 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 16ms | C | 4291 bytes | 2023-04-24 17:13:30 | |
93666 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 16ms | C | 4227 bytes | 2023-04-24 16:56:35 | |
93663 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 20ms | C | 4227 bytes | 2023-04-24 16:52:03 | |
93660 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 18ms | C | 4228 bytes | 2023-04-24 16:51:00 | |
91431 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 18ms | C | 4279 bytes | 2023-04-19 20:06:05 | |
91427 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 15ms | C | 4223 bytes | 2023-04-19 20:03:22 | |
91419 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 18ms | C | 4227 bytes | 2023-04-19 19:57:22 | |
91417 | 2022211349 | 泰拉瑞亚糕手 | Wrong Answer | 1200KB | 15ms | C | 4222 bytes | 2023-04-19 19:54:41 | |
91416 | 2022211349 | 泰拉瑞亚糕手 | Runtime Error | 1200KB | 6ms | C | 4254 bytes | 2023-04-19 19:52:09 | |
91415 | 2022211349 | 泰拉瑞亚糕手 | Runtime Error | 1200KB | 6ms | C | 4242 bytes | 2023-04-19 19:51:36 |