【2024华为OD机试真题-C卷D卷-200分】数字排列(C++/Java/Python)

本文详细解析了华为在线开发者(OD)机试中的一道题目,涉及数字排列问题。题目要求从给定的四个不重复数字中,根据特定规则(2和5,6和9可互换)找出第N个排列。通过回溯算法解决,同时介绍了输入判断和代码实现(C++和Java)。
摘要由CSDN通过智能技术生成

【华为OD机试】-(A卷+B卷+C卷+D卷)-2024真题合集目录

2024华为OD机试题库-(C卷+D卷)-(JAVA、Python、C++)

题目描述

小明负责公司年会,想出一个趣味游戏:

屏幕给出 1 ~ 9 中任意 4 个不重复的数字,大家以最快时间给出这几个数字可拼成的数字从小到大排列位于第 N 位置的数字,其中 N 为给出数字中最大的(如果不到这么多数字则给出最后一个即可)。

注意:

  • 2 可以当作 5 来使用,5 也可以当作 2 来使用进行数字拼接,且屏幕不能同时给出 2 和 5;
  • 6 可以当作 9 来使用,9 也可以当作 6 来使用进行数字拼接,且屏幕不能同时给出 6 和 9。

如给出:1,4,8,7,则可以拼接的数字为:

1,4,7,8,14,17,18,41,47,48,71,74,78,81,84,87,147,148,178 ... (省略后面的数字), 那么第 N (即8)个的数字为 41。

输入描述

输入以逗号分隔的 4 个 int 类型整数的字符串

输出描述

输出为这几个数字可拼成的数字从小到大排列位于第 N (N为输入数字中最大的数字)位置的数字,如果输入的数字不在范围内或者有重复,则输出-1。

用例1
输入 1,4,8,7
输出 41
说明

可以构成的数字按从小到大排序为:

1,4,7,8,14,17,18,41,47,48,71,74,78,81,84,87,147,148,178  ... (省略后面的数字),

故第8个为41

用例2 
输入 2,5,1
输出 -1
说明 2和5不能同时出现
用例3 
输入 3,0,9
输出 -1
说明 0不在1到9范围内
用例4 
输入 3,9,7,8
输出 39
说明

注意9可以当6使用,所以可以构成的数字按从小到大排序为:3,6,7,8,9,36,37,38,39,63,67,68,73,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2024剑指offer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值