题目
有 N 块二手市场收集的银饰,每块银饰的重量都是正整数,收集到的银饰会被熔化用于打造新的饰品。
每一回合,从中选出三块最重的银饰,然后一起熔掉。
假设银饰的重量分别为 x 、y和z,且 x ≤ y ≤ z。那么熔掉的可能结果如下:
如果 x == y == z,那么三块银饰都会被完全熔掉;
如果 x == y 且 y != z,会剩余重量为 z - y 的银块无法被熔掉;
如果 x != y 且 y == z,会剩余重量为 y - x 的银块无法被熔掉;
如果 x != y 且 y != z,会剩余重量为 z - y 与 y - x 差值 的银块无法被熔掉。
最后,
如果剩余两块,返回较大的重量(若两块重量相同,返回任意一块皆可)
如果只剩下一块,返回该块的重量
如果没有剩下,就返回 0
输入描述
输入数据为两行:
第一行为银饰数组长度 n,1 ≤ n ≤ 40,
第二行为n块银饰的重量,重量的取值范围为[1,2000],重量之间使用空格隔开
输出描述
如果剩余两块,返回较大的重量(若两块重量相同,返回任意一块皆可);
如果只剩下一块,返回该块的重量;
如果没有剩下,就返回 0。
用例
输入
3
1 1 1
输出
0
解题思路
将银饰的重量存储在一个数组中,并对数组进行升序排序。然后,通过循环模拟融化银饰的过程,每次移除最重的三块银饰并计算剩余银饰的重量。剩余银饰按照升序插入到已排序的数组中,并根据剩余
这是一个关于解决华为在线开发者面试(OD)的编程问题,涉及Java编程。题目要求处理熔化银饰的过程,每次选择三块最重的银饰并计算剩余重量。解题思路是先对银饰重量排序,然后模拟熔化过程,更新剩余银饰的重量。最终根据剩余银饰的数量返回相应结果。
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



