华为od机试 整理扑克牌
2023-03-14 本文已影响0人
梦想橡皮擦
本期题目:整理扑克牌 🃏
题目 📝
给定一组数字,表示扑克牌的牌面数字,忽略扑克牌的花色,请安如下规则对这一组扑克牌进行整理。
- 步骤一: 对扑克牌进行分组,规则如下
- 当牌面数字相同张数大于等于
4
时,组合牌为炸弹
; -
三张相同牌面数字+两张
相同牌面数字,且三张牌与两张牌不相同时,组合牌为葫芦
; -
三张相同牌面数字
,组合牌为三张
, -
两张相同牌面数字
,组合牌为对子
, - 剩余没有相同的牌则为
单张
- 当牌面数字相同张数大于等于
- 步骤二: 对上述组合牌进行由大到小排列,规则如下:
- 不同类型组合牌之间由大到小排列规则: 炸弹 > 葫芦 > 三张 > 对子 > 单张
- 相同类型组合牌之间,除葫芦外,按组合牌全部牌面数字加总,由大到小排列
- 葫芦则先按三张相同牌面数字加总,由大到小排列,三张相同牌面数字加总相同时,再按另外两张牌面数字加总,由大到小排列;
- 由于葫芦大于三张,因此如果能形成更大的组合牌,也可以将三张拆分为两张或一张,其中的两张可以和其他三张重新组合成葫芦,剩下的一张为单张;
- 步骤三:
- 当存在多个可能组合方案时,按如下规则排序取最大的一个组合牌:
- 依次对组合方案中的组合牌进行大小比较,规则同上;
- 当组合方案 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 机试的流程包括题目分发、答题、代码实现和自动评估等多个环节,每个环节都需要应聘者严格按照要求完成。