这是一道代码压缩题。与传统的算法竞赛题目不同的是,这道题目将额外给出一些语言的标准代码实现,你只需要专注于在尽可能缩短代码长度的同时,保证满足题目约束的输入数据相同时输出不会发生变化即可。我们给本题目提供的 C++ 代码在 5K 左右,另外还提供 C、java、python 的对应实现,这些代码可以通过附加文件一栏下载压缩包。你可以直接提交标准代码并获得基础分数,但如果你的目标是获得这道题的最高分数,在时间充足的情况下还是建议你能够仔细阅读题目描述和标准代码实现,确保自己能够充分理解题目的要求和代码的含义,在这之后再开始你的代码压缩之旅。祝你好运。
在 C++ 等高级语言中,除了 int 和 float 等基本类型外,通常还可以自定义结构体类型。在本题当中,你需要模拟一种类似 C++ 的高级语言的结构体定义方式,并计算出相应的内存占用等信息。
在这种语言中,基本类型共有 4 种: byte , short , int , long ,分别占据 1,2,4,8 字节的空间。
定义一个结构体类型时,需要给出类型名和成员,其中每个成员需要按顺序给出类型和名称。类型可以为基本类型,也可以为先前定义过的结构体类型。注意,定义结构体类型时不会定义具体元素,即不占用内存。
定义一个元素时,需要给出元素的类型和名称。元素将按照以下规则占据内存:
int 类型需要对齐到 4 字节,其余同理。int 和 short 的结构体类型需要对齐到 4 字节。以下是一个例子(以 C++ 语言的格式书写):
struct d {
short a;
int b;
short c;
};
d e;
该代码定义了结构体类型 d 与元素 e。元素 e 包含三个成员 e.a, e.b, e.c,分别占据第 0∼1 , 4∼7 , 8∼9 字节的地址。由于类型 d 需要对齐到 4 字节,因此 e 占据了第 0∼11 字节的地址,大小为 12 字节。
你需要处理 n 次操作,每次操作为以下四种之一:
. 来访问结构体类型的成员。如 a.b.c ,表示 a 是一个已定义的元素,它是一个结构体类型,有一个名称为 b 的成员,它也是一个结构体类型,有一个名称为 c 的成员。你需要输出如上被访问的最内层元素的起始地址。ERR 。对于结构体类型的对齐要求和大小,形式化的定义方式如下:
对于定义元素时的内存排布,形式化的定义方式如下:
第一行:一个正整数 n(1≤n≤100) ,表示操作的数量。
接下来若干行,依次描述每个操作,每行第一个正整数 op(1≤op≤4) 表示操作类型:
所有定义的结构体类型名、成员名称和定义的元素名称均由不超过 10 个字符的小写字母组成,且都不是 byte,short,int,long(即不与基本类型重名)。
所有定义的结构体类型名和元素名称互不相同,同一结构体内成员名称互不相同。但不同的结构体可能有相同的成员名称,某结构体内的成员名称也可能与定义的结构体或元素名称相同。
保证所有操作均符合题目所述的规范和要求,即结构体的定义不会包含不存在的类型、不会访问不存在的元素或成员等。
保证任意结构体大小及定义的元素占据的最高内存地址均不超过 1018 。
输出 n 行,依次表示每个操作的输出结果,输出要求如题目描述中所述。
5
1 a 2
short aa
int ab
1 b 2
a ba
long bb
2 b x
3 x.ba.ab
4 10
8 4
16 8
0
4
x.bb
结构体类型 a 中,short 类型的成员 aa 占据第 0∼1 字节地址,int 类型的成员 ab 占据第 4∼7 字节地址。又由于其对齐要求为 4 字节,可得其大小为 8 字节。由此可同理计算出结构体类型 b 的大小为 16 字节,对齐要求为 8 字节。