#P09005. 约瑟夫问题
约瑟夫问题
题目背景
据说著名犹太历史学家Josephus有过以下的故事:在罗马人占领乔塔帕特后, 个犹太人与Josephus及他的朋友躲到一个山洞中, 个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式, 个人排成一个圆圈,由第 个人开始报数,每报数到第 人该人就必须自杀,然后再由下一个重新报数,直到所有人都自杀身亡为止。Josephus要他的朋友先假装遵从,他将朋友与自己安排在第 个和第 个位置,于是逃过了这场死亡游戏。
题目描述
将问题简化, 个人围成一个圆圈,每个人的编号依次是 。从第一个人开始数数,数到 的人出圈。然后由出圈的下一个人重新数数,数到 的人又出圈……
记第 个出圈人的姓名为 ,性别为 ,那么可以产生一个字符串 :
$name_1 \enspace sex_1 \enspace name_2 \enspace sex_2 \enspace ... \enspace sex_{n-1} \enspace name_n \enspace sex_n \enspace name_1$
对于姓名字符串 ,记 为字符串 每个字符的序号的累加和( 和 的序号都是 ,其他字母依次类推),例如 。
记 $T = \sum\limits_{i=1}^{n}f(name_i) = f(name_1)+f(name_2)+...+f(name_n)$。
对于性别字符串 ,记 为按照下述规则转换成的字符串:如果 为 Male
则转换为 +
,否则转换为 *
,可知 ,。
由上述计算规则,可知由字符串 可以衍生出来新的字符串 :
$f(name_1) \enspace g(sex_1) \enspace f(name_2) \enspace g(sex_2) \enspace ... \enspace g(sex_{n-1}) \enspace f(name_n) \enspace g(sex_n) \enspace f(name_1)$
易知 是一个计算表达式。请你计算出这个表达式的结果,因为结果可能很大,你只需要输出这个结果 的最终结果。
需要特别注意的是, 可能远大于 。
输入格式
第 行是两个正整数 ;
紧接着有 行,依次是编号从 开始的 个人的姓名和性别,姓名和性别都是不包含空格且长度不超过 的字符串(只会出现大小写英文字母),性别只会是 Male
或 Femal
中的一种,两者之间用一个空格隔开。
输出格式
一共 行:
第一行是按照规则产生的表达式,需要注意的是运算符号和数字之间用一个空格隔开;
第二行是 个整数,分别是题目中的 和最终计算结果,两者之间用一个空格隔开。
输入输出样例
5 3
Jerry Male
Jack Male
Lucy Femal
Tim Male
Sara Femal
57 * 71 + 35 * 21 + 39 + 57
223 195
样例说明
对于输入样例,依次出圈的人的信息如下(分别是序号、姓名、性别):
3 Lucy Femal
1 Jerry Male
5 Sara Femal
2 Jack Male
4 Tim Male
产生的原字符串 是:
Lucy Femal Jerry Male Sara Femal Jack Male Tim Male Lucy
由题意,可知: f("Lucy")=57,f("Jerry")=71,f("Sara")=35,f("Jack")=21,f("Tim")=39
按照规则转换出的计算表达式 是:57 * 71 + 35 * 21 + 39 + 57
,计算结果是 4878
由题意,可知 T = 57 + 71 + 35 + 21 + 39 = 223
,所以最终结果是 4878 % 223 = 195
说明/提示
👀️ 对于的数据,。