当前位置: 首页 > news >正文

【LeetCode】3309. 连接二进制表示可形成的最大数值(递归|回溯|位运算)

LeetCode 3309. 连接二进制表示可形成的最大数值(中等)

      • 题目描述
      • 解题思路
      • Java代码

题目描述

题目链接:LeetCode 3309. 连接二进制表示可形成的最大数值(中等)
给你一个长度为 3 的整数数组 nums。

现以某种顺序 连接 数组 nums 中所有元素的 二进制表示 ,请你返回可以由这种方法形成的 最大数值。

注意 任何数字的二进制表示不含前导零。

示例 1:

输入: nums = [1,2,3]
输出: 30
解释:
按照顺序 [3, 1, 2] 连接数字的二进制表示,得到结果 “11110”,这是 30 的二进制表示。

示例 2:

输入: nums = [2,8,16]
输出: 1296
解释:
按照顺序 [2, 8, 16] 连接数字的二进制表述,得到结果 “10100010000”,这是 1296 的二进制表示。

提示:

nums.length == 3
1 <= nums[i] <= 127

解题思路

1.整体思路:使用递归回溯的方式尝试构造所有的拼接方案(构造全排列),取拼接方案中数值最大的即可。递归回溯法的关键在于:每次尝试之后,进行递归回退时要撤销尝试,将状态恢复成尝试之前的状态。

2.实现细节:开一个数组 v i s vis vis 来记录元素是否被选取过, v i s [ i ] vis[i] vis[i] 表示第 i i i 个数是否被选取过( 0 0 0 没选过, 1 1 1 选过)。每次尝试从 n u m s nums nums 数组中选取一个没被选过的数 n u m s [ i ] nums[i] nums[i] 拼接得到 c a n c a t cancat cancat ,将 v i s [ i ] vis[i] vis[i] 置为 1 1 1,表示该数已被选取过。当 n u m s nums nums 中的数都被选过时得到一种拼接方式,直接返回 c a n c a t cancat cancat 。每次回退时取消当前尝试,将 v i s [ i ] vis[i] vis[i] 恢复为 0 0 0,将 c a n c a t cancat cancat 恢复成之前的取值。在尝试的过程中更新拼接方案的最大取值。

3.如何实现二进制数的拼接:当前要拼接的数 n u m s [ i ] nums[i] nums[i] 二进制有几位,就把 c o n c a t concat concat 左移几位,然后将当前的数 n u m s [ i ] nums[i] nums[i] 加到 c o n c a t concat concat 上就实现了拼接。

Java代码

public class Solution {public int maxGoodNumber(int[] nums) {int vis[] = new int[nums.length];return dfs(0, 0, nums, vis);}/*** count:   已经选取的数的个数* concat:  拼接得到的数* nums:    可选数的数组* vis[i]:  第i个数是否被选取过*/int dfs(int count, int concat, int nums[], int vis[]) {if (count == nums.length) {// 所有的数的被选过,得到最终拼接的数return concat;}int res = Integer.MIN_VALUE;for (int i = 0; i < nums.length; i++) {// 判断当前数是否拼接过if (vis[i] == 0) {int x = nums[i], temp = concat;while (x > 0) {x = x >> 1;concat = concat << 1;}// 尝试拼接concat += nums[i];vis[i] = 1;// 可行拼接中取最大值res = Math.max(res, dfs(count + 1, concat, nums, vis));// 尝试完之后复原到拼接前的数concat = temp;vis[i] = 0;}}return res;}
}
http://www.xdnf.cn/news/909217.html

相关文章:

  • 在 Caliper 中执行不同合约的方法
  • Varjo如何帮助Entrol最大化其XR模拟器的性能
  • 探索GIS局部放电监测:PRPD与PRPS图谱的奥秘
  • 好子集的数目之解决方案
  • EDA断供危机下的冷思考:中国芯片设计软件的破局之道优雅草卓伊凡
  • Executors for C++- A Long Story
  • C++.OpenGL (4/64)纹理(Texture)
  • Vue3 GSAP动画库绑定滚动条视差效果 绑定滚动条 滚动条动画 时间轴
  • 破壁焕新能:DeviceNET转EtherNet/IP网关赋能烟草智能制造跃迁
  • Redis 主从 + 哨兵集群部署
  • Python爬虫伪装
  • 校招 Java 面试基础题目解析学习指南含新技术实操要点
  • Android第十三次面试总结基础
  • 【工具变量】上市公司企业华证esg数据集(2009-2024年)
  • 在Window上安装和配置VTK9.x,并在QT项目中调试VTK是否可用
  • 2025远离Deno和Fresh
  • 5G 核心网中 NF 选择机制:基于优先级、权重与负载分担的策略解析
  • 靶场(十九)--靶场体会小白分享--Billyboss
  • Langgraph实战--在Agent中加入人工反馈
  • OLED(SSD306)移植全解-基于IIC
  • 零基础完成 Token 创建的全流程教学
  • 芋道源码 - 本地文件上传配置与实现
  • 【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分
  • 配置sudo免密却不生效的问题
  • 【图论 强连通分量】P1653 [USACO04DEC] Cow Ski Area G|普及+
  • for(;;) 和while(1) 的无限循环用法对比,优缺点说明
  • PHP:Web 开发的强大基石与未来展望
  • 给网站添加live2d看板娘
  • 当主观认知遇上机器逻辑:减少大模型工程化中的“主观性”模糊
  • WHAT - script type=“module“