CONTEST ID : 1128 - 2023春-计导课设-9-12班-文件练习

文件操作练习。注意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);
*/


SERVER TIME : 2025-09-19 15:26:56
Finished

STATUS : End    OPEN : Private
Start Time : 2023-03-20 20:00:00
End Time : 2023-05-04 23:59:00


Problem ID    User    Language    Result   

RunID User Nick Name Problem ID Result Memory Time Language Code Length Submit Time
880322022211325LJessiAccepted
1072KB
11ms
C1396 bytes2023-04-12 23:15:26
880282022211325LJessiWrong Answer
1072KB
11ms
C1371 bytes2023-04-12 23:10:11
880252022211325LJessiWrong Answer
1072KB
11ms
C1335 bytes2023-04-12 23:08:47
880172022211325LJessiCompile Error
0KB
0ms
C1344 bytes2023-04-12 22:58:51
880122022211325LJessiCompile Error
0KB
0ms
C1323 bytes2023-04-12 22:54:02
836052022211325LJessiAccepted
1192KB
10ms
C1636 bytes2023-04-06 00:10:51
836032022211325LJessiCompile Error
0KB
0ms
C1566 bytes2023-04-06 00:10:17
836022022211325LJessiAccepted
1192KB
10ms
C1636 bytes2023-04-06 00:07:59
835972022211325LJessiTime Limit Exceed
1192KB
7049ms
C1640 bytes2023-04-06 00:04:54
835892022211325LJessiWrong Answer
1192KB
10ms
C1577 bytes2023-04-06 00:00:21
754612022211325LJessiAccepted
1192KB
10ms
C1951 bytes2023-03-30 22:49:33
754562022211325LJessiWrong Answer
1192KB
9ms
C2007 bytes2023-03-30 22:46:17
754372022211325LJessiWrong Answer
1192KB
9ms
C1995 bytes2023-03-30 22:39:12
754312022211325LJessiWrong Answer
1192KB
12ms
C1993 bytes2023-03-30 22:37:30
739422022211325LJessiAccepted
1200KB
13ms
C2606 bytes2023-03-30 00:23:02
739412022211325LJessiAccepted
1200KB
12ms
C3528 bytes2023-03-30 00:21:49
739402022211325LJessiWrong Answer
1200KB
13ms
C3295 bytes2023-03-30 00:19:39
739372022211325LJessiWrong Answer
1200KB
13ms
C2640 bytes2023-03-30 00:16:43
739342022211325LJessiWrong Answer
1200KB
11ms
C2640 bytes2023-03-30 00:11:30
739302022211325LJessiRuntime Error
1200KB
7ms
C2651 bytes2023-03-30 00:09:15
739192022211325LJessiRuntime Error
1200KB
6ms
C3283 bytes2023-03-29 23:59:32
739152022211325LJessi*Accepted64825
1200KB
13ms
C3511 bytes2023-03-29 23:57:44
739112022211325LJessiRuntime Error
1200KB
7ms
C3255 bytes2023-03-29 23:56:54
738992022211325LJessiRuntime Error
1200KB
7ms
C3253 bytes2023-03-29 23:52:57
738892022211325LJessiTime Limit Exceed
1200KB
1772ms
C2508 bytes2023-03-29 23:45:57