华为OD机试 整理扑克牌
最近更新的博客
- 华为 od 2023 | 什么是华为 od,od 薪资待遇,od 机试题清单 https://dream.blog.csdn.net/article/details/128980730
- 华为 OD 机试真题大全,用 Python 解华为机试题 | 机试宝典 https://dream.blog.csdn.net/article/details/129221789
- 【华为 OD 机试】全流程解析+经验分享,题型分享,防作弊指南) https://blog.csdn.net/hihell/article/details/129111620
- 华为 od 机试,独家整理 已参加机试人员的实战技巧 https://dream.blog.csdn.net/article/details/129270511
使用说明
参加华为 od 机试,一定要注意不要完全背诵代码,需要理解之后模仿写出,通过率才会高。
华为 OD 清单查看地址: https://blog.csdn.net/hihell/category_12225286.html
华为 OD 详细说明: https://dream.blog.csdn.net/article/details/128980730
本篇题解:整理扑克牌
题目
给定一组数字,表示扑克牌的牌面数字,忽略扑克牌的花色,请安如下规则对这一组扑克牌进行整理。
- 步骤一: 对扑克牌进行分组,规则如下
- 当牌面数字相同张数大于等于
4
时,组合牌为炸弹
; 三张相同牌面数字+两张
相同牌面数字,且三张牌与两张牌不相同时,组合牌为葫芦
;三张相同牌面数字
,组合牌为三张
,两张相同牌面数字
,组合牌为对子
,- 剩余没有相同的牌则为
单张
- 当牌面数字相同张数大于等于
- 步骤二: 对上述组合牌进行由大到小排列,规则如下:
- 不同类型组合牌之间由大到小排列规则: 炸弹 > 葫芦 > 三张 > 对子 > 单张
- 相同类型组合牌之间,除葫芦外,按组合牌全部牌面数字加总,由大到小排列
- 葫芦则先按三张相同牌面数字加总,由大到小排列,三张相同牌面数字加总相同时,再按另外两张牌面数字加总,由大到小排列;-- 橡皮擦整理
- 由于葫芦大于三张,因此如果能形成更大的组合牌,也可以将三张拆分为两张或一张,其中的两张可以和其他三张重新组合成葫芦,剩下的一张为单张;
- 步骤三:
- 当存在多个可能组合方案时,按如下规则排序取最大的一个组合牌:
- 依次对组合方案中的组合牌进行大小比较,规则同上;
- 当组合方案 A 中的第 N 个组合牌 > 组合方案 B 中的第 N 个组合牌时,即组合方案 A 大于组合方案 B;-- 橡皮擦整理
输入
第一行为空格分隔的 N 个正整数,每个整数取值范围 [1,13],N 的取值范围 [1,1000]
输出
经重新排列后的扑克牌数字列表,每个数字以空格分隔
题解地址 📤
- ⭐️ 华为 OD 机考 Python https://dream.blog.csdn.net/article/details/128995233
- ⭐️ 华为 OD 机考 C++ https://dream.blog.csdn.net/article/details/129209963
- ⭐️ 华为 OD 机考 JS https://dream.blog.csdn.net/article/details/129114477
- ⭐️ 华为 OD 机考 JAVA https://dream.blog.csdn.net/article/details/129907664
- ⭐️ 华为 OD 机考 Golang https://dream.blog.csdn.net/article/details/130467011
- ⭐️ 华为 OD 机考真 C 语言 https://dream.blog.csdn.net/article/details/129344183
华为 OD 机试
华为 OD 机试是华为外包人员入职的重要考试之一,通常包括多个部分,如英语测试、数学测试、逻辑思维测试等。 考试内容主要针对外包人员的专业技能和工作经验,以及对公司文化和价值观的理解。 考试形式通常采用笔试和面试相结合的方式,其中笔试包括阅读理解、逻辑思维、数学计算等多种题型。 面试环节通常包括个人介绍、工作经验、职业规划等方面的问题,同时还会针对考生的英语水平进行面试。 华为 OD 机试的目的是评估外包人员的专业技能、工作经验和团队合作能力,以确保他们能够胜任公司的工作要求。
华为 od 机试的题目类型主要有以下几种:
简单的编程题:考察基本的编程语言知识和语法,如变量、循环、条件判断、函数等。 数据结构设计题:考察对常用的数据结构如数组、链表、栈、队列、树、图等的理解和应用,如创建、遍历、查找、排序、修改等。 算法设计题:考察对常用的算法如递归、分治、贪心、动态规划、回溯、搜索等的理解和应用,如求解最优化问题、组合问题、排列问题等。 编程和调试题:考察在给定的代码框架下,能否快速分析问题和解决问题,如修复代码错误、优化代码性能、增加代码功能等。