华为OD机试 - 符合要求的元组的个数 - 回溯(Java 2023 B卷 100分)

news2024/9/23 4:30:30

在这里插入图片描述

目录

    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示
      • 1、输入
      • 2、输出
      • 3、说明

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

一、题目描述

给定一个整数数组nums、一个数字k,一个整数目标值target,请问nums中是否存在k个元素,使其相加结果为target,请输出所有符合条件且不重复的k元组的个数。

取值范围:

2 <= nums.length <= 200
-109 < numslil < 109
-109 < target< 109
2 <= k <= 100

二、输入描述

第一行输入整数数组nums;
第二行输入数字k;
第三行输入整数目标值target;

三、输出描述

输出第一行是符合要求的元组个数。

四、解题思路

  1. 输入整数数组nums;
  2. 输入数字k;
  3. 输入整数目标值target;
  4. 递归计算数组nums中是否有k个数字之和等于target,并且组合不能重复;
  5. 输出符合条件的数量okSum;

五、Java算法源码

// 符合条件的数量
public static int okSum = 0;
public static int target;
public static List<List<Integer>> numsList = new ArrayList<>();

/**
 * 从nums数组中取k个数,使其和等于target
 */
public static void main(String[] args) {

    Scanner sc = new Scanner(System.in);

    // 整数数组nums
    int[] nums = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();
    // 输入数字k
    int k = sc.nextInt();
    // 输入整数目标值target
    target = sc.nextInt();

    calculate(nums, k, new ArrayList<>(), 0);

    System.out.println(okSum);
}

/**
 * @param nums  数组
 * @param n     n个数
 * @param list  选取的数字
 * @param index 数组的索引
 */
public static void calculate(int[] nums, int n, List<Integer> list, int index) {

    if (n == 0) {
        int count = 0;
        // 集合内数字之和
        for (Integer i : list) {
            count += i;
        }
        // 符合条件且不重复
        if (count == target && !isContains(list)) {
            numsList.add(new ArrayList<>(list));
            okSum++;
        }
    } else {
        for (int i = index; i < nums.length; i++) {
            list.add(nums[i]);
            calculate(nums, n - 1, list, i + 1);
            list.remove(list.size() - 1);
        }
    }
}

/**
 * 集合是否重复
 */
public static boolean isContains(List<Integer> list) {
    Collections.sort(list);
    for (List<Integer> temp : numsList) {
        Collections.sort(temp);
        if (list.size() == temp.size()) {
            if (list.containsAll(temp)) {
                return true;
            }
        }
    }
    return false;
}

六、效果展示

1、输入

1 2 5 8 4
2
9

2、输出

2

3、说明

[1,8],[5,4]满足条件。

在这里插入图片描述


🏆下一篇:华为OD机试真题 Java 实现【简易内存池】【2023 B卷 200分 考生抽中题】

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

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

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

相关文章

pdf加密如何解除?这样解除加密很简单

pdf加密如何解除&#xff1f;有时&#xff0c;我们可能会收到一些加密的PDF文件&#xff0c;它们不允许我们对其进行编辑或打印。这时&#xff0c;我们需要使用PDF解密工具&#xff0c;以便能够轻松地解除PDF加密并对其进行编辑。那么接下来就给大家介绍一下pdf加密解除的方法。…

Vue基础2:传值方法

Description 传值就是为了联动&#xff0c;能够及时准确传值获取值才是王道。 Valuation Methods props和$emit props是父传子&#xff0c;$emit是子传父。 props的使用 父组件传出值 <tableList ref"table" :options"options" :header-data"C…

GE MRP680489 IS200VTCCH1CBB印刷电路板

信号处理&#xff1a; 这个印刷电路板通常用于信号处理和数据传输&#xff0c;可以与其他设备或模块进行通信&#xff0c;如传感器、执行器或控制器。 通信接口&#xff1a; IS200VTCCH1CBB 可能具有多种通信接口&#xff0c;用于与其他设备和系统进行数据交换&#xff0c;包括…

通过「内网穿透」技术,实现出差期间远程访问企业局域网中的象过河ERP系统

文章目录 概述1.查看象过河服务端端口2.内网穿透3. 异地公网连接4. 固定公网地址4.1 保留一个固定TCP地址4.2 配置固定TCP地址 5. 使用固定地址连接 概述 ERP系统对于企业来说重要性不言而喻&#xff0c;不管是财务、生产、销售还是采购&#xff0c;都需要用到ERP系统来协助。…

8月31日-9月 第六章 案例:MySQL主从复制与读写分离(面试重点,必记)

本章结构 案例概述 案例前置知识点 详细图示 1、什么是读写分离&#xff1f; 读写分离&#xff0c;基本的原理是让主数据库处理事务性增、改、删操作&#xff08;INSERT、UPDATE、DELETE&#xff09;&#xff0c;而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导…

基于Python的IOS自动化测试环境搭建

文章目录 一、测试架构介绍1.1 WebDriverAgent原理分析1.2 tidevice原理分析二、环境安装2.1 iOS 设备安装 WebDriverAgent2.2 安装iTunes2.3 安装tidevice2.4 安装facebook-wda自动化三、操作流程一、测试架构介绍 以下为测试架构原理图 手机端的WDA Runner(WebDriverAgent…

如何通过网络远程访问电脑?

怎么远程访问公司电脑&#xff1f; “你好&#xff0c;我想通过网络从外面远程访问公司的电脑&#xff0c;这可能吗&#xff1f;您知道如何通过网络远程访问另一台电脑吗&#xff1f;” 借助远程访问工具&#xff0c;我们是可以通过网络远程访问公司电脑的。通过…

静电离子风棒的联网智能实时监控的操作步骤

静电离子风棒的联网智能实时监控可以通过以下步骤进行&#xff1a; 1. 获取数据&#xff1a;将静电离子风棒上的传感器与网络连接&#xff0c;以获取实时数据。传感器可能包括温度传感器、湿度传感器、电流传感器等&#xff0c;用于监测离子风棒的工作状态和环境信息。 2. 数…

Elasticsearch:自动使用服务器时间设置日期字段并更新时区

在大多数情况下&#xff0c;你的数据包含一个以 create_date 命名的字段。 即使没有日期字段&#xff0c;处理各种格式和时区的日期对数据仓库来说也是一个重大挑战。 与此类似&#xff0c;如果要检测变化的数据&#xff0c;则必须准确设置日期字段。 在 Elasticsearch 中还有…

蓝牙运动耳机哪个牌子好、好用的运动蓝牙耳机推荐

作为一个热爱运动的人&#xff0c;我对耳机非常关注。我相信许多喜欢运动的人在锻炼时都会佩戴耳机&#xff0c;这样可以为运动增添一份乐趣&#xff0c;享受自己喜爱的音乐或聆听有趣的小说&#xff0c;激发内心的动力。但很多人都不知道要怎么选一款优质的运动耳机&#xff0…

C语言:字符函数和字符串函数(一篇拿捏字符串函数!)

目录 求字符串长度&#xff1a; 1. strlen(字符串长度) 长度不受限制函数&#xff1a; 2. strcpy(字符串拷贝) 3. strcat(字符串追加) 4. strcmp(字符串比较) 长度受限制函数&#xff1a; 5. strncpy(字符串拷贝) 6. strncat(字符串追加) 7. strncmp(字符串比较) 字…

关于大学考研与不考研自己一点看法

据网上报道&#xff0c;2023年研究生报考人数为474万&#xff0c;相较22年报名人数457万人,同比增长 17 万 2023年的考研录取率为20&#xff05;,如今,在北京的硕士博士生超过本科生人数 学历的贬值&#xff0c;通胀,速度远远超乎了想象 近几年的考研热,考公,考编热是年年基本上…

完美解决xinput1_3.dll丢失问题,修复xinput1_3.dll文件

在电脑游戏中经常遇到xinput1_3.dll丢失的问题&#xff0c;这个问题是因为系统缺少该文件而引起的。而且&#xff0c;这个问题很容易导致游戏无法正常运行&#xff0c;给玩家带来很大的烦恼。在本文中&#xff0c;我们将详细介绍如何修复这个问题&#xff0c;给大家详细的说明多…

YOLO目标检测——时间检测数据集下载分享

时间数据集是表示一天中不同时间的图像集合&#xff0c;日出和日落被视为同一类别。数据集包含日出/日落、白天场景和夜间场景的图像&#xff0c;并已重新缩放为 224 x 224 x 3 像素&#xff0c;描绘了不同的地点和不同的天气条件&#xff0c;如晴朗的天空&#xff0c;阴天等。…

Chrome自动升级了,找不到最新版本的webdriver怎么办?

Chrome自动升级了,找不到最新版本的webdriver怎么办? 背景解决办法 背景 我用Selenium开发了Facebook和Linkedin爬虫&#xff0c;有些新需求要调一下&#xff0c;今天启动selenium时有报错&#xff0c;报错如下&#xff1a;selenium.common.exceptions.SessionNotCreatedExce…

pygame实现物体运动拖尾尾迹-渐隐版

解说文案&#xff1a; 视频讲解&#xff1a;https://www.bilibili.com/video/BV14w411S74E/ 上一集我们实现了物体本体形式的拖尾&#xff0c;这一集我们基于上一集来实现物体逐渐变透明到消失的拖尾。 上集我们也说过&#xff0c;逐渐变透明到消失的物体拖尾只不过是给物体…

Qt无边框青绿色主题

收费产品&#xff0c;学生党、闹眼子党勿扰 收费金额&#xff1a;500元 1 概述 最近因项目需要&#xff0c;写了一个炫酷的青绿色、无边框界面&#xff0c;和3DSMax的界面有点类似。 2 截图 首先看看3DSMax的界面 不知道大家看出来没&#xff0c;这个ui其实很简单&#xff…

15. Docker实战监控神器Uptime Kuma

目录 1、前言 2、什么是Uptime Kuma? 3、Docker部署Uptime Kuma 3.1、安装 3.2、访问 3.3、配置 3.4、集成飞书机器人 3.5、效果 1、前言 在利用Docker部署项目时&#xff0c;我们需要时刻知道已部署的容器的状态。且通常会把所有的站点监控配置到云平台上&#xff0c…

算法通关村十三关 | 辗转相除法、素数和丑数

1. 辗转相除法 辗转相除法又称欧几里得算法&#xff0c;求两个数的最大公因数&#xff0c;希腊数学家喜欢用图形来处理问题&#xff0c;于是将要求最大公约数问题转化为&#xff0c;以两个数字构成矩形&#xff0c;寻找可以铺满整个矩形的最大正方形的边长问题。 题目 例如8和1…

基于Spring Boot的企业门户网站设计与实现(Java+spring boot+MySQL)

获取源码或者论文请私信博主 演示视频&#xff1a; 基于Spring Boot的企业门户网站设计与实现&#xff08;Javaspring bootMySQL&#xff09; 使用技术&#xff1a; 前端&#xff1a;html css javascript jQuery ajax thymeleaf 微信小程序 后端&#xff1a;Java springboot…