文件操作练习。注意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 |
99887 | 2022211644 | apple | Accepted | 1068KB | 10ms | C | 855 bytes | 2023-05-02 01:00:09 | |
99844 | 2022211644 | apple | Accepted | 2052KB | 14ms | C | 1773 bytes | 2023-05-01 23:09:17 | |
99841 | 2022211644 | apple | Output Limit Exceed | 2052KB | 16ms | C | 1760 bytes | 2023-05-01 23:06:27 | |
99361 | 2022211644 | apple | Accepted | 1192KB | 12ms | C | 1817 bytes | 2023-05-01 10:19:31 | |
99354 | 2022211644 | apple | *Accepted96373 | 1196KB | 13ms | C | 1515 bytes | 2023-05-01 10:04:42 | |
99348 | 2022211644 | apple | Wrong Answer | 1196KB | 12ms | C | 1534 bytes | 2023-05-01 09:31:28 | |
99345 | 2022211644 | apple | Wrong Answer | 1196KB | 9ms | C | 1481 bytes | 2023-05-01 09:26:26 | |
99343 | 2022211644 | apple | Wrong Answer | 1192KB | 11ms | C | 1483 bytes | 2023-05-01 09:26:00 | |
99342 | 2022211644 | apple | Wrong Answer | 1196KB | 10ms | C | 1471 bytes | 2023-05-01 09:24:11 | |
99341 | 2022211644 | apple | Wrong Answer | 1196KB | 12ms | C | 1327 bytes | 2023-05-01 09:20:54 | |
99336 | 2022211644 | apple | Wrong Answer | 1192KB | 10ms | C | 1302 bytes | 2023-05-01 09:08:53 | |
99334 | 2022211644 | apple | Wrong Answer | 1192KB | 13ms | C | 1329 bytes | 2023-05-01 09:07:03 | |
99322 | 2022211644 | apple | Accepted | 1192KB | 10ms | C | 2835 bytes | 2023-05-01 01:00:43 | |
99318 | 2022211644 | apple | Wrong Answer | 1192KB | 10ms | C | 2843 bytes | 2023-05-01 00:56:37 | |
99317 | 2022211644 | apple | Runtime Error | 1192KB | 8ms | C | 2930 bytes | 2023-05-01 00:55:18 | |
99296 | 2022211644 | apple | Wrong Answer | 1192KB | 12ms | C | 2787 bytes | 2023-05-01 00:21:15 | |
99295 | 2022211644 | apple | Wrong Answer | 1192KB | 13ms | C | 2793 bytes | 2023-05-01 00:19:54 | |
99294 | 2022211644 | apple | Wrong Answer | 1192KB | 11ms | C | 2778 bytes | 2023-05-01 00:18:48 | |
98952 | 2022211644 | apple | Wrong Answer | 1192KB | 9ms | C | 1786 bytes | 2023-04-30 22:24:31 | |
98935 | 2022211644 | apple | *Accepted64610 | 1192KB | 9ms | C | 2959 bytes | 2023-04-30 22:20:33 | |
98914 | 2022211644 | apple | Wrong Answer | 1192KB | 8ms | C | 1784 bytes | 2023-04-30 22:14:11 | |
98905 | 2022211644 | apple | Wrong Answer | 1192KB | 11ms | C | 1771 bytes | 2023-04-30 22:11:31 | |
98891 | 2022211644 | apple | Wrong Answer | 1192KB | 10ms | C | 1784 bytes | 2023-04-30 22:06:51 | |
98886 | 2022211644 | apple | Wrong Answer | 1192KB | 9ms | C | 1783 bytes | 2023-04-30 22:05:18 | |
98884 | 2022211644 | apple | Wrong Answer | 1192KB | 7ms | C | 1766 bytes | 2023-04-30 22:04:38 | |
98861 | 2022211644 | apple | Wrong Answer | 1192KB | 10ms | C | 1777 bytes | 2023-04-30 21:56:30 | |
98834 | 2022211644 | apple | Wrong Answer | 1192KB | 8ms | C | 1763 bytes | 2023-04-30 21:50:18 | |
98831 | 2022211644 | apple | Wrong Answer | 1192KB | 9ms | C | 1764 bytes | 2023-04-30 21:48:33 | |
98819 | 2022211644 | apple | Wrong Answer | 1192KB | 9ms | C | 1763 bytes | 2023-04-30 21:41:34 | |
98811 | 2022211644 | apple | Wrong Answer | 1192KB | 10ms | C | 1758 bytes | 2023-04-30 21:37:41 |