bzoj#P1144. [CTSC2008]奥运抽奖volunteer
[CTSC2008]奥运抽奖volunteer
题目描述
距 2008 年北京奥运会开幕还有 90 天时,CTSC 准备为志愿者们举行一次抽奖活动。作为志愿者的一员,你对这次抽奖活动自然是万分期待。 CTSC 委员会介绍了抽奖活动的规则。
设总共有 个参加抽奖的志愿者,开始时每一个志愿者领取一个 到 的号码。任意两个志愿者领取的号码不同。屏幕的正中央是五福娃的头像,他们不停的眨眼欢迎大家。开始抽奖时,工作人员按下屏幕旁边的按钮,等待屏幕上的画面静止下来。这时,福娃们都停止眨眼了。当然,画面静止时,有的福娃的眼睛可能是睁开的,有的是闭上的。如果所有福娃的眼睛都闭上了,工作人员需要重新按一下按钮。这样,直到至少有一个福娃的眼睛是睁开的。接着,工作人员开始观察有哪些福娃的眼睛是睁开的。
工作人员对五个福娃都标了号。贝贝、晶晶、欢欢、迎迎、妮妮的标号分别是 (工作人员认为 和 都不是好数字)。定义幸运数字如下:
- 如果一个福娃的眼睛是睁开的,那么他(她)对应的标号 就是幸运数字。
- 如果数字 和 (可能相等)都是幸运数字,那么他们的乘积 也是幸运数字。
- 其他的数字都不是幸运数字。
用 表示所有数字的集合,例如,如果贝贝、晶晶的眼睛是睁开的,欢欢、迎迎、妮妮的眼睛是闭上的,则 。令 表示第 大的幸运数字。例如,上面的例子中, 等等。接着,工作人员开始随机产生两个数,小的数是 ,大的数字是 。定义集合 为:
(其中 表示x整除y) 定义一个自然数的有限子集的特征值 如下:
- 空集的特征值为0。
- 对于非空集合 ,令 为 中的最小元素,则
其中, 表示把 删除元素 后的集合, 是一个给定的非负整数。在 和 产生以后,中奖的志愿者就确定 了,他的号码是除以 的余数。工作人员会产生多次 ,这样就能形成多个中奖者。但是,抽奖现场的程序需要很长的时间才能算出中奖的志愿者。出于对中奖结果的热切期待,你便想要重新写一下计算程序,于是,你的目光移向了前面的键盘……
输入格式
输入的第一行给出用空格隔开的五个数,每个数不是 就是 ,分别表示贝贝、晶晶、欢欢、迎迎、妮妮的眼睛是否睁开。 对应眼睛闭上, 对应眼睛睁开。 个数不可能都是 。
第二行给出了用空格隔开的两个数, 和 。 其中 表示参加抽奖的志愿者的人数, 如前所述,用来计算集合的特征值。
第三行给出了数 ,表示抽取的 和 的次数。
接下来的 行,每一行有两个数 ,中间用空格隔开,表示一次抽奖产生的两个数。
输出格式
输出共 行,每一行一个整数,表示一次抽奖中中奖者的号码。顺序与输入的 对 一一对应。当然,一个人可能中奖多次。
1 0 0 1 0
10001 2
3
1 10
2 12
4 15
3265
5816
0
数据规模与约定
。
。