问题描述
有 n 个字符串,每个字符串都是由 A-J 的大写字符构成。现在你将每个字符映射为一个 0-9 的数字,不同字符映射为不同的数字。这样每个字符串就可以看做一个整数,唯一的要求是这些整数必须是正整数且它们的字符串不能有前导零。现在问你怎样映射字符才能使得这些字符串表示的整数之和最大?
输入描述
每组测试用例仅包含一组数据,每组数据第一行为一个正整数 n , 接下来有 n 行,每行一个长度不超过 12 且仅包含大写字母 A-J 的字符串。 n 不大于 50,且至少存在一个字符不是任何字符串的首字母。
输出描述
输出一个数,表示最大和是多少
示例 1
输入
1 | 2 |
输出
1 | 1875 |
解题思路
我们可以通过计算权值,把权值最高的映射成9
,次之映射成8
,以此类推。
例如:
ABC
A的权值为100,B的权值为10,C的权值为1————①
BCA
B的权值为100,C的权值为10,A的权值为1————②
①②权值相加
A的权值为101,B的权值为110,C的权值为11
110 × 9 + 101 × 8 + 11 × 7 = 1875
但是我们要注意前导零。当把一个字符映射成0
时,检查是否出现在最高位,如果出现则找上一个字符,直到找到权重最小的又不会出现在最高位的字符,把这个字符映射成0
,其他字符按序映射。
解题代码
1 | package main |