欢迎光临散文网 会员登陆 & 注册

华为OD 整理扑克牌

2023-03-15 10:43 作者:发量迷人的乔喻  | 我要投稿

本期题目:整理扑克牌 🃏

题目 📝

给定一组数字,表示扑克牌的牌面数字,忽略扑克牌的花色,请安如下规则对这一组扑克牌进行整理。

  • 步骤一: 对扑克牌进行分组,规则如下

    1. 当牌面数字相同张数大于等于4时,组合牌为炸弹

    2. 三张相同牌面数字+两张相同牌面数字,且三张牌与两张牌不相同时,组合牌为葫芦

    3. 三张相同牌面数字,组合牌为三张

    4. 两张相同牌面数字,组合牌为对子

    5. 剩余没有相同的牌则为单张

  • 步骤二: 对上述组合牌进行由大到小排列,规则如下:

    1. 不同类型组合牌之间由大到小排列规则: 炸弹 > 葫芦 > 三张 > 对子 > 单张

    2. 相同类型组合牌之间,除葫芦外,按组合牌全部牌面数字加总,由大到小排列

    3. 葫芦则先按三张相同牌面数字加总,由大到小排列,三张相同牌面数字加总相同时,再按另外两张牌面数字加总,由大到小排列;

    4. 由于葫芦大于三张,因此如果能形成更大的组合牌,也可以将三张拆分为两张或一张,其中的两张可以和其他三张重新组合成葫芦,剩下的一张为单张;

  • 步骤三:

    1. 当存在多个可能组合方案时,按如下规则排序取最大的一个组合牌:

    2. 依次对组合方案中的组合牌进行大小比较,规则同上;

    3. 当组合方案 A 中的第 N 个组合牌 > 组合方案 B 中的第 N 个组合牌时,即组合方案 A 大于组合方案 B;

输入 📥

第一行为空格分隔的 N 个正整数,每个整数取值范围 [1,13],N 的取值范围 [1,1000]

输出 📤

经重新排列后的扑克牌数字列表,每个数字以空格分隔

题解地址 📤

  • ⭐️ 华为 OD 机考 Python https://blog.csdn.net/hihell/article/details/128995233

  • ⭐️ 华为 OD 机考 C++ https://blog.csdn.net/hihell/article/details/129191778

  • ⭐️ 华为 OD 机考 JS https://blog.csdn.net/hihell/category_12201825.html

  • ⭐️ 华为 OD 机考 JAVA https://blog.csdn.net/hihell/category_12201821.html

  • ⭐️ 华为 OD 机考 Golang https://blog.csdn.net/hihell/category_12231589.html

  • ⭐️ 华为 OD 机考真 C 语言 https://blog.csdn.net/hihell/article/details/129344183

华为 OD 机试

华为 OD 机试需要多长时间?它的流程是怎样的?华为 OD 机试的时间长度因岗位要求而异,一般为 1-2 个小时。应聘者需要在规定时间内完成多个题目的答题和代码实现。华为 OD 机试的流程包括题目分发、答题、代码实现和自动评估等多个环节,每个环节都需要应聘者严格按照要求完成。


华为OD 整理扑克牌的评论 (共 条)

分享到微博请遵守国家法律