文件操作练习。注意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 |
102440 | 2022211322 | 豌豆黄冠 | Runtime Error | 1072KB | 12ms | C | 1953 bytes | 2023-05-04 23:47:49 | |
102125 | 2022211322 | 豌豆黄冠 | Runtime Error | 1072KB | 10ms | C | 1955 bytes | 2023-05-04 20:33:31 | |
102123 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 1961 bytes | 2023-05-04 20:32:33 | |
102122 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 1959 bytes | 2023-05-04 20:31:58 | |
102116 | 2022211322 | 豌豆黄冠 | *Accepted65033 | 1072KB | 14ms | C | 1838 bytes | 2023-05-04 20:28:05 | |
102082 | 2022211322 | 豌豆黄冠 | *Accepted64826 | 1192KB | 9ms | C | 2763 bytes | 2023-05-04 19:27:05 | |
102081 | 2022211322 | 豌豆黄冠 | *Accepted64826 | 1192KB | 11ms | C | 2626 bytes | 2023-05-04 19:25:33 | |
102080 | 2022211322 | 豌豆黄冠 | Runtime Error | 1192KB | 10ms | C | 2697 bytes | 2023-05-04 19:23:18 | |
102079 | 2022211322 | 豌豆黄冠 | Runtime Error | 1192KB | 11ms | C | 2714 bytes | 2023-05-04 19:20:20 | |
102078 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 2703 bytes | 2023-05-04 19:19:42 | |
101846 | 2022211322 | 豌豆黄冠 | Accepted | 1192KB | 9ms | C | 2291 bytes | 2023-05-04 11:57:38 | |
101817 | 2022211322 | 豌豆黄冠 | *Accepted65025 | 1192KB | 10ms | C | 2079 bytes | 2023-05-04 11:01:06 | |
101811 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 2226 bytes | 2023-05-04 10:49:52 | |
101808 | 2022211322 | 豌豆黄冠 | *Accepted65025 | 1192KB | 13ms | C | 2050 bytes | 2023-05-04 10:46:15 | |
101807 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 2051 bytes | 2023-05-04 10:45:18 | |
101803 | 2022211322 | 豌豆黄冠 | *Accepted65025 | 1192KB | 10ms | C | 2063 bytes | 2023-05-04 10:42:36 | |
101800 | 2022211322 | 豌豆黄冠 | *Accepted65025 | 1192KB | 10ms | C | 2061 bytes | 2023-05-04 10:39:10 | |
101611 | 2022211322 | 豌豆黄冠 | *Accepted64826 | 1192KB | 13ms | C | 2595 bytes | 2023-05-03 21:44:34 | |
101609 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 2595 bytes | 2023-05-03 21:43:14 | |
96286 | 2022211322 | 豌豆黄冠 | Accepted | 1200KB | 12ms | C | 2472 bytes | 2023-04-26 23:08:49 | |
96279 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1200KB | 12ms | C | 2469 bytes | 2023-04-26 23:02:46 | |
96274 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1200KB | 13ms | C | 2464 bytes | 2023-04-26 22:47:17 | |
96264 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1192KB | 12ms | C | 2494 bytes | 2023-04-26 22:28:33 | |
96260 | 2022211322 | 豌豆黄冠 | Time Limit Exceed | 1192KB | 1763ms | C | 2446 bytes | 2023-04-26 22:25:20 | |
96254 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1192KB | 13ms | C | 2417 bytes | 2023-04-26 22:19:56 | |
96253 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1192KB | 13ms | C | 2417 bytes | 2023-04-26 22:19:10 | |
91511 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1192KB | 10ms | C | 2416 bytes | 2023-04-19 22:36:35 | |
91497 | 2022211322 | 豌豆黄冠 | Wrong Answer | 1192KB | 9ms | C | 2305 bytes | 2023-04-19 22:18:07 | |
91488 | 2022211322 | 豌豆黄冠 | Time Limit Exceed | 1192KB | 1766ms | C | 2249 bytes | 2023-04-19 22:01:04 | |
91487 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 2248 bytes | 2023-04-19 22:00:27 | |
91484 | 2022211322 | 豌豆黄冠 | Time Limit Exceed | 1192KB | 1773ms | C | 2247 bytes | 2023-04-19 21:50:22 | |
91483 | 2022211322 | 豌豆黄冠 | Compile Error | 0KB | 0ms | C | 2247 bytes | 2023-04-19 21:49:46 |