最新华为OD机试真题-数字排列游戏(200分)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员

✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解

👏 感谢大家的订阅➕ 和 喜欢💗

最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测

最新华为OD机试目录: https://www.nowcoder.com/discuss/636153620743897088?sourceSSR=users

📎在线评测链接

数字排列游戏(200分)

alt

🌍 评测功能需要 =>订阅专栏<= 后联系清隆解锁~

🍓OJ题目截图

alt

🍰 数字排列游戏

问题描述

K 小姐负责公司年会,想出一个趣味游戏:屏幕给出 中任意 个不重复的数字,大家需要以最快时间给出这几个数字可拼成的数字从小到大排列位于第 位置的数字,其中 为给出数字中最大的。如果不到这么多数字则给出最后一个即可。

注意:

  • 可以当作 来使用, 也可以当作 来使用进行数字拼接,且屏幕不能同时给出
  • 可以当作 来使用, 也可以当作 来使用进行数字拼接,且屏幕不能同时给出

例如,给出的数字:, , , 则可以拼接的数字为:, , , , , , , , , , , , , , , , , , ...(省略后面的数字)。因此,第 (即 )个数字为

输入格式

输入以逗号分隔的 类型整数的字符串。

输出格式

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

样例输入

样例一

1,4,8,7

样例二

2,5,1,4

样例三

3,0,9,1

样例四

3,9,7,8

样例输出

样例一

41

样例二

-1

样例三

-1

样例四

39

样例解释

样例一

可以构成的数字按从小到大排序为:, , , , , , , , , , , , , , , , , , ...(省略后面的数字),故第 个数字为

样例二

不能同时出现。

样例三

不在 的范围内。

样例四

注意 可以当 使用,所以可以构成的数字按从小到大排序为:, , , , , , , , , , , , , , , , .... (省略后面的数字),故第 个为

数据范围

输入的数字范围为 ,且不重复。

题解

这道题的关键在于处理数字的排列组合,并且考虑到 以及 的互换使用。我们需要生成所有可能的数字组合,然后进行排序,最后根据最大数字的位置输出相应的结果。

参考代码

  • Python
def main():
    import sys
    input = sys.stdin.read
    w = list(map(int, input().strip().split(',')))
    w.sort()
    st = set(w)
    k = max(w)
    dic = {2: 5, 5: 2, 6: 9, 9: 6}
    vis = [False] * 4
    res = []

    def dfs(u, num, cnt):
        if u == cnt:
            res.append(num)
            return
        for i in range(4):
            if vis[i]:
                continue
            vis[i] = True
            dfs(u + 1, num * 10 + w[i], cnt)
            if w[i] in dic:
                dfs(u + 1, num * 10 + dic[w[i]], cnt)
            vis[i] = False

    if 0 in st or (2 in st and 5 in st) or (6 in st and 9 in st):
        print(-1)
    else:
        for i in range(1, 5):
            dfs(0, 0, i)
        res.sort()
        if k > len(res):
            print(res[-1])
        else:
            print(res[k - 1])

if __name__ == "__main__":
    main()
  • Java
import java.util.*;

public class Main {
  

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

最新华为OD机试-E+D卷 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD-E/D卷的题目汇总和(Java/Cpp/Python)三语言解析 + 部分题目提供OJ在线评测

全部评论

相关推荐

1 1 评论
分享
牛客网
牛客企业服务