文件操作练习。注意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 |
93590 | 2022211356 | Fiona | Accepted | 1192KB | 12ms | C | 3195 bytes | 2023-04-24 14:51:56 | |
91599 | 2022211356 | Fiona | Accepted | 1068KB | 22ms | C | 1588 bytes | 2023-04-20 10:47:53 | |
91597 | 2022211356 | Fiona | Runtime Error | 1068KB | 19ms | C | 1557 bytes | 2023-04-20 10:45:14 | |
91596 | 2022211356 | Fiona | Runtime Error | 1068KB | 18ms | C | 1557 bytes | 2023-04-20 10:41:09 | |
91371 | 2022211356 | Fiona | Runtime Error | 1068KB | 16ms | C | 1639 bytes | 2023-04-19 17:29:32 | |
91312 | 2022211356 | Fiona | Runtime Error | 1068KB | 17ms | C | 1640 bytes | 2023-04-19 12:48:12 | |
91308 | 2022211356 | Fiona | Runtime Error | 1068KB | 18ms | C | 1642 bytes | 2023-04-19 11:54:13 | |
91082 | 2022211356 | Fiona | Runtime Error | 1068KB | 17ms | C | 1641 bytes | 2023-04-18 22:13:14 | |
90930 | 2022211356 | Fiona | Runtime Error | 1068KB | 17ms | C | 1642 bytes | 2023-04-18 20:59:18 | |
90922 | 2022211356 | Fiona | Compile Error | 0KB | 0ms | C | 1803 bytes | 2023-04-18 20:54:25 | |
90624 | 2022211356 | Fiona | Compile Error | 0KB | 0ms | C | 1803 bytes | 2023-04-18 16:26:03 | |
90622 | 2022211356 | Fiona | Compile Error | 0KB | 0ms | C | 1803 bytes | 2023-04-18 16:24:30 | |
90593 | 2022211356 | Fiona | Runtime Error | 1068KB | 19ms | C | 1728 bytes | 2023-04-18 15:16:26 | |
90524 | 2022211356 | Fiona | Runtime Error | 1068KB | 40ms | C | 1487 bytes | 2023-04-18 11:58:42 | |
90107 | 2022211356 | Fiona | Time Limit Exceed | 1192KB | 8807ms | C | 2278 bytes | 2023-04-17 16:36:23 | |
89940 | 2022211356 | Fiona | Wrong Answer | 1192KB | 10ms | C | 1831 bytes | 2023-04-17 01:53:42 | |
89939 | 2022211356 | Fiona | Compile Error | 0KB | 0ms | C | 2046 bytes | 2023-04-17 01:41:00 | |
89937 | 2022211356 | Fiona | Output Limit Exceed | 1196KB | 9ms | C | 1082 bytes | 2023-04-17 01:06:28 | |
89935 | 2022211356 | Fiona | Wrong Answer | 1192KB | 12ms | C | 2122 bytes | 2023-04-17 00:27:19 | |
89929 | 2022211356 | Fiona | Output Limit Exceed | 1192KB | 7ms | C | 2010 bytes | 2023-04-17 00:06:14 | |
89921 | 2022211356 | Fiona | Wrong Answer | 1192KB | 12ms | C | 854 bytes | 2023-04-16 23:53:19 | |
86234 | 2022211356 | Fiona | Accepted | 1196KB | 12ms | C | 2549 bytes | 2023-04-10 15:40:52 | |
84672 | 2022211356 | Fiona | Wrong Answer | 1196KB | 9ms | C | 2492 bytes | 2023-04-07 22:28:59 | |
83267 | 2022211356 | Fiona | Output Limit Exceed | 1068KB | 12ms | C | 1939 bytes | 2023-04-05 21:24:44 | |
82903 | 2022211356 | Fiona | Accepted | 1192KB | 11ms | C | 3187 bytes | 2023-04-05 16:52:17 | |
82838 | 2022211356 | Fiona | Compile Error | 0KB | 0ms | C | 3140 bytes | 2023-04-05 16:19:11 |