文件操作练习。注意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 |
96107 | 2022211258 | lzjslzhhh | Wrong Answer | 1068KB | 14ms | C | 935 bytes | 2023-04-26 19:26:57 | |
96098 | 2022211258 | lzjslzhhh | Wrong Answer | 1068KB | 10ms | C | 983 bytes | 2023-04-26 19:07:44 | |
96087 | 2022211258 | lzjslzhhh | *Accepted65101 | 1068KB | 11ms | C | 1853 bytes | 2023-04-26 18:58:30 | |
96084 | 2022211258 | lzjslzhhh | Runtime Error | 1068KB | 9ms | C | 1853 bytes | 2023-04-26 18:58:14 | |
96081 | 2022211258 | lzjslzhhh | *Accepted65101 | 1068KB | 11ms | C | 1929 bytes | 2023-04-26 18:54:50 | |
96079 | 2022211258 | lzjslzhhh | Runtime Error | 1068KB | 9ms | C | 1943 bytes | 2023-04-26 18:53:44 | |
96074 | 2022211258 | lzjslzhhh | Wrong Answer | 1068KB | 12ms | C | 943 bytes | 2023-04-26 18:47:01 | |
96072 | 2022211258 | lzjslzhhh | Runtime Error | 1068KB | 9ms | C | 943 bytes | 2023-04-26 18:46:33 | |
96048 | 2022211258 | lzjslzhhh | Wrong Answer | 1068KB | 11ms | C | 943 bytes | 2023-04-26 18:14:34 | |
95984 | 2022211258 | lzjslzhhh | Wrong Answer | 1068KB | 11ms | C | 943 bytes | 2023-04-26 16:49:47 | |
95965 | 2022211258 | lzjslzhhh | Wrong Answer | 1068KB | 11ms | C | 970 bytes | 2023-04-26 16:36:36 | |
95727 | 2022211258 | lzjslzhhh | Accepted | 1192KB | 11ms | C | 918 bytes | 2023-04-26 10:44:33 | |
94983 | 2022211258 | lzjslzhhh | Accepted | 1192KB | 13ms | C | 2024 bytes | 2023-04-25 20:07:44 | |
94980 | 2022211258 | lzjslzhhh | Wrong Answer | 1192KB | 11ms | C | 2024 bytes | 2023-04-25 20:05:19 | |
94970 | 2022211258 | lzjslzhhh | Wrong Answer | 1192KB | 14ms | C | 1898 bytes | 2023-04-25 20:02:40 | |
94969 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1898 bytes | 2023-04-25 20:02:05 | |
94966 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1897 bytes | 2023-04-25 20:01:39 | |
94961 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1898 bytes | 2023-04-25 20:00:56 | |
94956 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1886 bytes | 2023-04-25 19:59:47 | |
94955 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1888 bytes | 2023-04-25 19:59:18 | |
94953 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1888 bytes | 2023-04-25 19:57:54 | |
94952 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 1888 bytes | 2023-04-25 19:57:22 | |
84868 | 2022211258 | lzjslzhhh | Accepted | 1192KB | 15ms | C | 2648 bytes | 2023-04-08 11:56:31 | |
84863 | 2022211258 | lzjslzhhh | Wrong Answer | 1192KB | 14ms | C | 2643 bytes | 2023-04-08 11:53:50 | |
84861 | 2022211258 | lzjslzhhh | Wrong Answer | 1192KB | 13ms | C | 2643 bytes | 2023-04-08 11:53:24 | |
84857 | 2022211258 | lzjslzhhh | Wrong Answer | 1192KB | 11ms | C | 2525 bytes | 2023-04-08 11:33:15 | |
84855 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 2511 bytes | 2023-04-08 11:31:19 | |
80406 | 2022211258 | lzjslzhhh | Compile Error | 0KB | 0ms | C | 2384 bytes | 2023-04-03 17:25:25 |