赞
踩
有 N 块二手市场收集的银饰,每块银饰的重量都是正整数,收集到的银饰会被熔化用于打造新的饰品。 每一回合,从中选出三块最重的银饰,然后一起熔掉。假设银饰的重量分别为 x 、y 和 z,且 x <= y <= z。那么熔掉的可能结果如下:
1. 如果 x == y == z,那么三块银饰都会被完全熔掉;
2. 如果 x == y 且 y != z,会剩余重量为 z - y 的银块无法被熔掉;
3. 如果 x != y 且 y == z,会剩余重量为 y - x 的银块无法被熔掉;
4. 如果 x != y 且 y != z,会剩余重量为 z - y 与 y - x 差值的银块无法被熔掉。
5. 最后,如果剩余两块,返回较大的重量(若两块重量相同,返回任意一块皆可);如果只剩 下一块,返回该块的重量;如果没有剩下,就返回 0。
输入数据为两行; 第一行为银饰数组长度 n,1 ≤ n ≤ 40; 第二行为 n 块银饰的重量,重量的取值范围为[1,2000],重量之间使用空格隔开;
如果剩余两块,返回较大的重量(若两块重量相同,返回任意一块皆可);如果只剩下一块,返回该块的重量;如果没有剩下,就返回 0。
示例1 输入输出示例仅供调试,后台判题数据一般不包含示例
3 1 1 1
0
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。