数字排列 - 华为OD统一考试(C卷)

news2024/9/27 17:24:32

OD统一考试(C卷)

分值: 200分

题解: Java / Python / C++

alt

题目描述

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

屏幕给出 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,4

输出:
-1

说明:
2 和 5 不能同时出现。

示例3

输入:
3,0,9,1


输出:
-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, 76, 78, 79, 83 .... (省略后面的数字),故第9个为 39

题解

这道题目是一道组合数字的问题,需要根据给定的数字组合出所有可能的数字,然后进行排序,最后找到第n位的数字。

解题思路如下:

  1. 首先,读取输入的四个数字,构建成一个集合。
  2. 判断集合中是否有非法数字,即数字小于1或大于9的情况,以及是否同时出现了2和5、6和9。
  3. 扩展集合,将2和5等价,将6和9等价。
  4. 根据集合中的数字,生成所有可能的组合数字,包括一位数和两位数。
  5. 将生成的所有数字进行排序。
  6. 返回排序后第n位的数字。

为什么组合数字,只包括一位数和两位数?

  1. n为输入数字中最大的数字, 因此最大值是 9
  2. 输入的数字是 4 个不重复的数字,因此组成的数字个数至少为:
    • 一位数: 至少有 4 个
    • 二位数: 至少有 12 个
  3. 因此, 一位和两位的组合数至少 16 个, 答案拼成的数字从小大大排列位于第 n 个数肯定就包含在里面。

Java

import java.util.Arrays;
import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;
/**
 * @author code5bug
 */
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);

        Set<Integer> s = new HashSet<>();
        String[] inputArr = in.nextLine().split(",");
        for (String str : inputArr) {
            s.add(Integer.parseInt(str.trim()));
        }

        int result = solve(s);
        System.out.println(result);
    }

    public static int solve(Set<Integer> s) {
        int m = Integer.MAX_VALUE, mx = Integer.MIN_VALUE;
        for (int num : s) {
            m = Math.min(m, num); // 获取最小值
            mx = Math.max(mx, num); // 获取最大值
        }

        if (m < 1 || mx > 9) { // 存在非法的数字
            return -1;
        }

        // 不能同时出现
        if ((s.contains(2) && s.contains(5)) || (s.contains(6) && s.contains(9))) {
            return -1;
        }

        int n = mx; // n为输入数字中最大的数字

        // 为了方便组合数字,则需将可以等同的数字也加入进去
        if (s.contains(2) || s.contains(5)) {
            s.add(2);
            s.add(5);
        }
        if (s.contains(6) || s.contains(9)) {
            s.add(6);
            s.add(9);
        }

        // 拼接的数字
        Set<Integer> collect = new HashSet<>(s); // 一位数

        // 二位数的组合
        for (int x : s) {
            for (int y : s) {
                // 每个数字只能使用一次
                if (x != y && x * y != 2 * 5 && x * y != 6 * 9) {
                    collect.add(x * 10 + y);
                }
            }
        }

        // 对组成的数字排序,然后返回第 n 位的数字
        Integer[] sortedArray = collect.toArray(new Integer[0]);
        Arrays.sort(sortedArray);
        return sortedArray[n - 1];
    }
}

Python


def solve(s) -> int:
    m, mx = min(s), max(s)
    if m < 1 or mx > 9:  # 存在非法的数字
        return -1

    # 不能同时出现
    if (2 in s and 5 in s) or (6 in s and 9 in s):
        return -1

    # n为输入数字中最大的数字
    n = mx

    # 为了方便组合数字,则需将可以等同的数字也加入进去
    if (2 in s or 5 in s):
        s.add(2)
        s.add(5)
    if (6 in s or 9 in s):
        s.add(6)
        s.add(9)

    # 拼接的数字
    collect = set(s)  # 一位数

    # 二位数的组合
    for x in s:
        for y in s:
            # 每个数字只能使用一次
            if x != y and x * y != 2 * 5 and x * y != 6 * 9:
                collect.add(x * 10 + y)

    # 对组成的数字排序,然后返回第 n 位的数字
    sorted_array = sorted(list(collect))
    return sorted_array[n - 1]


if __name__ == "__main__":
    arr = set(map(int, input().split(",")))
    print(solve(arr))

C++

#include <bits/stdc++.h>
using namespace std;

int solve(set<int>& s)
{

    int m = *s.begin(), mx = *(--s.end());
    if (m < 1 || mx > 9) {   // 存在非法的数字
        return -1;
    }

    // 不能同时出现
    if ((s.find(2) != s.end() && s.find(5) != s.end()) || (s.find(6) != s.end() && s.find(9) != s.end())) {
        return -1;
    }

    int n = mx;   // n为输入数字中最大的数字

    // 为了方便组合数字,则需将可以等同的数字也加入进去
    if (s.find(2) != s.end() || s.find(5) != s.end()) {
        s.insert(2);
        s.insert(5);
    }
    if (s.find(6) != s.end() || s.find(9) != s.end()) {
        s.insert(6);
        s.insert(9);
    }

    // 拼接的数字
    set<int> collect(s);   // 一位数

    // 二位数的组合
    for (auto x : s) {
        for (auto y : s) {
            // 每个数字只能使用一次
            if (x != y && x * y != 2 * 5 && x * y != 6 * 9) {
                collect.insert(x * 10 + y);
            }
        }
    }

    // 对组成的数字排序,然后返回第 n 位的数字
    vector<int> sorted_array(collect.begin(), collect.end());
    sort(sorted_array.begin(), sorted_array.end());
    return sorted_array[n - 1];
}

int main()
{
    set<int> s;
    for (int i = 0, x; i < 4; i++) {
        cin >> x;
        s.insert(x);
        if (cin.peek() == ',') cin.ignore();
    }
    cout << solve(s) << endl;
    return 0;
}
    

‍❤️‍有考友通过专栏已经快速通过机考,都是原题哦~~ 💪

📝 订阅 http://t.csdnimg.cn/lifXk

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1517174.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

稀碎从零算法笔记Day17-LeetCode:有效的括号

题型&#xff1a;栈 链接&#xff1a;20. 有效的括号 - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1a;LeetCode 题目描述&#xff08;红字为笔者添加&#xff09; 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 …

CentOS无法解析部分网站(域名)

我正在安装helm软件&#xff0c;参考官方文档&#xff0c;要求下载 get-helm-3 这个文件。 但是我执行该条命令后&#xff0c;报错 连接被拒绝&#xff1a; curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 # curl: (7) Fai…

Spring Boot 集成 WebSocket 实例 | 前端持续打印远程日志文件更新内容(模拟 tail 命令)

这个是我在 CSDN 的第一百篇原则博文&#xff0c;留念&#x1f60e; #1 需求说明 先说下项目结构&#xff0c;后端基于 Spring Boot 3&#xff0c;前端为 node.js 开发的控制台程序。现在希望能够在前端模拟 tail 命令&#xff0c;持续输出后端的日志文件。 #2 技术方案 #2.…

手动创建线程池各个参数的意义?

今天我们学习线程池各个参数的含义&#xff0c;并重点掌握线程池中线程是在什么时机被创建和销毁的。 线程池的参数 首先&#xff0c;我们来看下线程池中各个参数的含义&#xff0c;如表所示线程池主要有 6 个参数&#xff0c;其中第 3 个参数由 keepAliveTime 时间单位组成。…

人工智能课题、模型源码

人工智能研究生毕业&#xff5e;深度学习、计算机视觉、时间序列预测&#xff08;LSTM、GRU、informer系列&#xff09;、python、人工智能项目代做和指导&#xff0c;各种opencv图像处理、图像分类模型&#xff08;vgg、resnet、mobilenet、efficientnet等&#xff09;、人脸检…

.NET高级面试指南专题十七【 策略模式模式介绍,允许在运行时选择算法的行为】

介绍&#xff1a; 策略模式是一种行为设计模式&#xff0c;它允许在运行时选择算法的行为。它定义了一系列算法&#xff0c;将每个算法封装到一个对象中&#xff0c;并使它们可以互相替换。这使得算法可独立于使用它的客户端变化。 原理&#xff1a; 策略接口&#xff08;Strat…

使用BBDown下载bilibili视频的方法

一款命令行式哔哩哔哩下载器. Bilibili Downloader. 下载地址 https://github.com/nilaoda/BBDown 功能 番剧下载(Web|TV|App) 课程下载(Web) 普通内容下载(Web|TV|App) 合集/列表/收藏夹/个人空间解析 多分P自动下载 选择指定分P进行下载 选择指定清晰度进行下载 下载外挂字幕…

基于springboot+vue实现电子商务平台管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现电子商务平台管理系统演示 研究的目的和意义 据我国IT行业发布的报告表明&#xff0c;近年来&#xff0c;我国互联网发展呈快速增长趋势&#xff0c;网民的数量已达8700万&#xff0c;逼近世界第一&#xff0c;并且随着宽带的实施及降价&#xff0c;每天约有…

实现微服务:匹配系统

HTTP与WebSocket协议 1. HTTP协议是无状态的&#xff0c;每次请求都是独立的&#xff0c;服务器不会保存客户端的状态信息。而WebSocket协议是有状态的&#xff0c;一旦建立连接后&#xff0c;服务器和客户端可以进行双向通信&#xff0c;并且可以保持连接状态&#xff0c;服务…

基于Java的海南旅游景点推荐系统(Vue.js+SpringBoot)

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 用户端2.2 管理员端 三、系统展示四、核心代码4.1 随机景点推荐4.2 景点评价4.3 协同推荐算法4.4 网站登录4.5 查询景点美食 五、免责说明 一、摘要 1.1 项目介绍 基于VueSpringBootMySQL的海南旅游推荐系统&#xff…

Let’s Move Sui , 一起来学习吧

Let’s Move Sui是一个全新的交互式学习平台&#xff0c;通过SuiFrens的帮助教您如何在Sui上构建。设计供新手和经验丰富的开发者使用&#xff0c;Let’s Move Sui提供了一次非凡的Sui开发之旅&#xff0c;利用了Move在Sui上的独特之处&#xff0c;从基于对象的数据模型的基础知…

WPF —— Grid网格布局

1 &#xff1a;Grid网格布局简介 Grid为WPF中最常用的布局容器, 作为View中的主要组成部分, 负责框架中整体的页面布局。 2&#xff1a;网格标签Grid.ColumnDef Grid.ColumnDefinitions自定义列 只能设置宽度 不能设置高度ColumnDefinition 每一个列可以设置宽度&#xff0c;…

windows 免密码ssh登录linux

参考&#xff1a;https://blog.csdn.net/qq285744011/article/details/118293937 1&#xff09;windows先生成公钥私钥 ssh-keygen -t rsa -C "你的邮箱地址"生成后放在用户命令.ssh文件下 2&#xff09;把公钥复制到linux /root/.ssh/authorized_keys 3)然后就可…

未解决的问题:字符数组中元素的个数

情形1&#xff1a; #include<stdio.h> int main() {int arr_int1[10];int arr_int2[]{1,2,3,4,5};char arr_char1[10];char arr_char2[]"world";char arr_char3[]{h,e,l,l,o};int i;i0;while(arr_char2[i]!\0){i;}printf("%d\n",i);i0;while(arr_ch…

【MMDetection3D实战4】利用mmdet3d进行训练

文章目录 1. 介绍1.1 训练流程1.2 测试及验证2. 训练过程演示2.1 准备数据集并处理2.2 加载并修改配置文件2.3 启动训练2.4 测试1. 介绍 1.1 训练流程 MMDetection3D(mmdet3d)和OpenMMlab其他代码库是一样的,在训练的时候需要准备好一个配置文件,在配置文件中定义好所使用的…

2.MongoDB与关系数据库对比

MongoDB的简单操作与比较 与关系数据库对比 MySQL与MongoDB都是开源的常用数据库&#xff0c;但是MySQL是传统的关系型数据库&#xff0c;MongoDB则是非关系型数据库&#xff0c;也叫文档型数据库&#xff0c;是一种NoSQL的数据库。它们各有各的优点&#xff0c;来看看他们之…

轮趣 IMU N100 九轴 IMU 在 ROS 下安装驱动

本篇介绍如何在ROS环境中使用 WHEELTEC N100 惯导模块。 轮趣 IMU N100 的 ROS 驱动程序下载链接&#xff1a;轮趣 IMU 资料 - 坚果云 - 云盘|网盘|企业网盘|同步|备份|无限空间|免费网络硬盘|企业云盘 1、CP2102 固定串口号 1.1 、修改串口号 在 Windows 中需要把 WHEELTE…

H5 宠物店官网源码

源码名称&#xff1a;H5宠物店官网源码 源码介绍&#xff1a;一款宠物店官网单页源码&#xff0c;可以用于开设宠物店宣传页、宠物店官网。源码H5自适应无后台。 需求环境&#xff1a;H5 下载地址&#xff1a; https://www.changyouzuhao.cn/11098.html

Linux-vim显示乱码

Linux运维工具-ywtool 目录 一.问题二.解决2.1 编辑VIM的配置文件2.2 添加以下内容 一.问题 用vim编辑的时候,中文显示乱码 二.解决 2.1 编辑VIM的配置文件 vim ~/.vimrc #如果这个文件不存在,创建一个即可2.2 添加以下内容 添加完成以后就不会在出现中文乱码了 set fil…

操作系统系列学习——CPU调度策略

文章目录 前言CPU调度策略 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招&#xff0c;计划学习操作系统并完成6.0S81&#xff0c;加油&#xff01; 本文总结自B站【哈工大】操作系统 李治军&#xff08;全32讲&#xff09; 老师课程讲的非常好&#xff0c;感谢 【哈工大…