文件操作练习。注意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 |
91183 | 2022211281 | Reyurd | Accepted | 1072KB | 11ms | C | 1594 bytes | 2023-04-18 23:33:09 | |
91177 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 10ms | C | 1583 bytes | 2023-04-18 23:26:37 | |
91176 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 12ms | C | 1586 bytes | 2023-04-18 23:25:29 | |
91170 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 12ms | C | 1609 bytes | 2023-04-18 23:21:52 | |
91165 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 10ms | C | 1609 bytes | 2023-04-18 23:17:17 | |
91157 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 9ms | C | 1609 bytes | 2023-04-18 23:09:07 | |
91155 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 9ms | C | 1627 bytes | 2023-04-18 23:07:52 | |
91147 | 2022211281 | Reyurd | Runtime Error | 1072KB | 10ms | C | 1614 bytes | 2023-04-18 23:02:16 | |
91143 | 2022211281 | Reyurd | Runtime Error | 1072KB | 12ms | C | 1577 bytes | 2023-04-18 23:00:42 | |
91119 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 9ms | C | 1504 bytes | 2023-04-18 22:50:12 | |
91115 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 12ms | C | 1504 bytes | 2023-04-18 22:47:31 | |
91114 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 12ms | C | 1506 bytes | 2023-04-18 22:46:22 | |
91108 | 2022211281 | Reyurd | Wrong Answer | 1072KB | 10ms | C | 1504 bytes | 2023-04-18 22:40:03 | |
89927 | 2022211281 | Reyurd | Accepted | 1192KB | 9ms | C | 1288 bytes | 2023-04-17 00:01:04 | |
89910 | 2022211281 | Reyurd | Wrong Answer | 1192KB | 11ms | C | 1163 bytes | 2023-04-16 23:28:09 | |
89901 | 2022211281 | Reyurd | Output Limit Exceed | 1192KB | 10ms | C | 1132 bytes | 2023-04-16 23:18:04 | |
89900 | 2022211281 | Reyurd | Output Limit Exceed | 1192KB | 12ms | C | 1090 bytes | 2023-04-16 23:14:27 | |
89882 | 2022211281 | Reyurd | Wrong Answer | 1192KB | 12ms | C | 1191 bytes | 2023-04-16 22:55:06 | |
89850 | 2022211281 | Reyurd | Runtime Error | 1200KB | 10ms | C | 1801 bytes | 2023-04-16 22:36:44 | |
89849 | 2022211281 | Reyurd | Runtime Error | 1200KB | 9ms | C | 1801 bytes | 2023-04-16 22:36:22 | |
87821 | 2022211281 | Reyurd | *Accepted65979 | 1196KB | 12ms | C | 1699 bytes | 2023-04-12 19:45:39 | |
87818 | 2022211281 | Reyurd | Wrong Answer | 1196KB | 10ms | C | 1118 bytes | 2023-04-12 19:39:11 | |
87815 | 2022211281 | Reyurd | Wrong Answer | 1196KB | 11ms | C | 1229 bytes | 2023-04-12 19:34:43 | |
87803 | 2022211281 | Reyurd | Wrong Answer | 1192KB | 10ms | C | 1089 bytes | 2023-04-12 19:08:19 | |
85309 | 2022211281 | Reyurd | Accepted | 1192KB | 13ms | C | 1892 bytes | 2023-04-08 22:11:34 | |
85304 | 2022211281 | Reyurd | Wrong Answer | 1192KB | 12ms | C | 1842 bytes | 2023-04-08 22:10:01 | |
85302 | 2022211281 | Reyurd | Wrong Answer | 1192KB | 11ms | C | 1875 bytes | 2023-04-08 22:07:29 |