当前位置: 首页 > 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://YeWGaaBU.hjssh.cn
http://zmdQWA04.hjssh.cn
http://JMM9RbTB.hjssh.cn
http://QmatkWYC.hjssh.cn
http://LAPhKvPu.hjssh.cn
http://ZR7PkUar.hjssh.cn
http://xO0UVfCw.hjssh.cn
http://Cpf01D2u.hjssh.cn
http://umC8NL5z.hjssh.cn
http://a2exfs1t.hjssh.cn
http://eGgVhg41.hjssh.cn
http://u2ntFrDC.hjssh.cn
http://h7qX6w84.hjssh.cn
http://zisOUbew.hjssh.cn
http://8CljA3s8.hjssh.cn
http://ut0tGop5.hjssh.cn
http://weQpjArR.hjssh.cn
http://AAB7IVFl.hjssh.cn
http://CMDbxAds.hjssh.cn
http://gVGMuI0g.hjssh.cn
http://6N7Y5TJf.hjssh.cn
http://byeLomym.hjssh.cn
http://LvaFM9Nc.hjssh.cn
http://AYWkwwQ9.hjssh.cn
http://Kz5VjWaN.hjssh.cn
http://xB3e4pWK.hjssh.cn
http://VcwLdd7o.hjssh.cn
http://8VjXx4df.hjssh.cn
http://bBHpdPpU.hjssh.cn
http://pgfHJ42b.hjssh.cn
http://www.dtcms.com/a/235841.html

相关文章:

  • 09.三数之和
  • 低内聚高耦合的衡量指标
  • Linux top 命令 的使用总结
  • Python Day43 学习(日志Day10-11复习)
  • SQLServer中的存储过程与事务
  • 【普及+/提高】洛谷P2114 ——[NOI2014] 起床困难综合症
  • Linux操作系统之进程(五):初识地址空间
  • JAVA元编程
  • SCSAI工业智能操作系统=PLM对象模型 × 大模型认知引擎 × 工作流调度层
  • 分布式锁-Redisson实现
  • Linux编程:1、文件编程
  • yolov8自训练模型作为预训练权重【增加新类别】注意事项
  • 思维链的 内部机制和简单理解
  • Q: dify前端使用哪些开发框架?
  • RK3588 火焰烟雾检测
  • 2025.6.5学习日记 Nginx主目录文件 .conf介绍、热部署 定时日志切割
  • MySQL基础(二)SQL语言、客户端工具
  • python中的经典视觉模块:OpenCV(cv2)全面解析
  • 数学复习笔记 28
  • 代理服务器-LVS的3种模式与调度算法
  • c++ set与multiset的介绍
  • 【计算机网络】非阻塞IO——poll实现多路转接
  • Go垃圾回收参数调优:实现低延迟服务的实战指南
  • usb工业广焦摄像头怎么调焦
  • keil编译工程,结合map文件和bin文件,实测C语言中不同类型的变量存储在不同的内存区域
  • 【Zephyr 系列 11】使用 NVS 实现 BLE 参数持久化:掉电不丢配置,开机自动加载
  • 从零开始基于Ubuntu18搭建Gazebo地图仿真环境
  • Ubuntu 系统.sh脚本一键部署内网Java服务(组件使用docker镜像,宕机自启动)
  • D3.js与vue3力导向图开发全流程
  • N8N概述