#HK5102. 「POI2009 R2」建筑师 Architect
「POI2009 R2」建筑师 Architect
题目描述
题目译自 XVI OI Olimpiada Informatyczna – II etap Architekci
国王 Bajtazar 计划兴建一座新宫殿,宣布举办建筑设计大赛,征集最佳方案。为激励建筑师加紧工作,他规定将按提交顺序评审设计。
这项任务声名显赫,吸引了全球建筑师向王室办公厅提交方案。提案数量庞大,Bajtazar 无暇逐一审阅,遂委托大法官初步筛选,遵循以下规则:
- 大法官需挑选 个方案,立即淘汰其余——Bajtazar 知晓自己最多只能审阅 个方案。
- 方案须按提交顺序呈交,Bajtazar 将依此顺序评审,符合其承诺。
- 在满足上述条件的所有 个方案序列中,大法官需选出最佳序列,定义如下:
序列 优于 ,若存在 ,使得前 个方案两序列等同(即 ,对 ),但第 个方案 。
方案源源不断提交,截止日期未定。大法官不愿临近截止才选方案,又恐出错惹国王震怒,遂向你求助。
编写程序,完成以下任务:
- 通过提供的库读取 和表示方案质量的序列。
- 确定符合规则的最佳 个方案序列。
- 通过库返回所选方案的质量。
交互方式
使用库需在程序中引入:
- C/C++:
#include "carclib.h" - Pascal:
uses parclib; - Java:无需额外操作,但运行时需确保编译好的库
jarclib.class与程序在同一目录。
库提供以下三个函数:
inicjuj:返回整数 ,表示结果序列应包含的方案数。需在程序开始时调用一次。- C/C++:
int inicjuj(); - Pascal:
function inicjuj(): longint; - Java:
public static int inicjuj();(jarclib类静态方法)
- C/C++:
wczytaj:第 次调用返回整数 ,表示第 个方案的质量(越大越好),或 ,表示无更多方案。方案总数未知,但保证至少 个,最多 个。需反复调用直至返回 ,不可多调用。- C/C++:
int wczytaj(); - Pascal:
function wczytaj(): longint; - Java:
public static int wczytaj();(jarclib类静态方法)
- C/C++:
wypisz:用于提交大法官选出的方案质量,需调用 次,第 次提交第 个方案的质量。第 次调用后程序终止。- C/C++:
void wypisz(int jakoscProjektu); - Pascal:
procedure wypisz(jakoscProjektu: longint); - Java:
public static void wypisz(int jakoscProjektu);(jarclib类静态方法)
- C/C++:
程序不得打开文件或使用标准输入输出。编译命令:
- C:
gcc -O2 -static carclib.c arc.c -lm - C++:
g++ -O2 -static carclib.c arc.cpp -lm - Java:
javac arc.java,需确保jarclib.class在同一目录。 - Pascal:
ppc386 -O2 -XS -Xt arc.pas,需确保parclib在同一目录。
示例库和参考代码位于 「文件」中。示例库从标准输入读取测试场景,格式如下:
- 第一行:正整数 。
- 后续行:每行一个正整数 ,表示第 个方案质量。
- 最后一行:,表示方案结束。
示例库将程序提交的 个方案质量输出到标准输出,每行一个。
样例
| C/C++ | Pascal | Java | 返回值及说明 |
|---|---|---|---|
k = inicjuj(); |
k := inicjuj(); |
k = jarclib.inicjuj(); |
,确定输出序列长度。 |
| 开始读取方案质量。 | |||
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
|
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
|
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
|
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
|
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
|
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
|
wczytaj(); |
wczytaj(); |
jarclib.wczytaj(); |
,方案读取结束。 |
| 输出结果序列: | |||
wypisz(12); |
wypisz(12);` |
jarclib.wypisz(12); |
|
wypisz(15); |
wypisz(15); |
jarclib.wypisz(15); |
|
wypisz(8); |
wypisz(8); |
jarclib.wypisz(8); |
|
数据范围与提示
详细子任务附加限制及分值如下表所示。
| 子任务 | 附加限制 | 分值 |
|---|---|---|
| 无附加限制 |